基于solo;从0开始搭建个人博客系统(小白保姆级教程)
B站视频教程地址,点击查看 : https://bilibili.com/video/BV1xz4y1k783?p=1
下面的文档为上面的视频笔记;可以配合视频教程使用。
教程介绍
个人博客
个人博客:https://blog.lupf.cn
CSDN : https://lupengfei.blog.csdn.net/
为什么要有自己的博客?
- 记录学习、开发心得;解决的问题、学习的知识;写出来和单纯装在脑子里是完全不一样的;记录一遍,影响更加深刻;
- 分享精神(开源精神),帮助其他人解决相同的问题,分享有趣的知识;
- 提升自身的level,扩大自己的影响力,结识更多的朋友;
- 云服务降低了门槛;不需要自己搞机器、办固定IP;入门级别的阿里云、腾讯云几百块钱一年;成本很低,但是足够个人博客的使用了。
- 审核机制的问题;某一些特殊的笔记,没办法发到共有的博客环境,那我们就可以放在主机的博客下面;
- 面试、找工作的加分项
搭建面临的问题
- 问题太多带来的恐惧
搭建的过程中不可避免的会出现问题,很多时候因为这些问题得不到有效的解决而被迫放弃;我想说的是,不要畏惧,直面问题刚一波,其实很多时候往往就是坚持一下,下一秒可能就找到解决方案了。 - 了解的知识面不够全面
麻雀虽小,五脏俱全;一个博客平台,虽然支持的功能就那么多,但是包含了一整套业务流程;数据库、前端、后台都有,然而并不是所有开发人员这些都是了解的;因此,因为一些不会的因素,给整个搭建带来了一些障碍。
教程的目的
本教程的最终目的,就是带大家解决搭建过程中的会遇到的问题;从0开始的一步步去构建;详细的讲解每一个步骤的创建过程。不管你是在校大学生、前端开发、后端开发。都可以轻松的将个人博客搭建起来。
为什么选SOLO
gitbub地址:https://github.com/88250/solo
docker仓库地址: https://hub.docker.com/r/b3log/solo
solo是一个很轻量级的博客框架,搭建起来容易,一个服务,一个mysql就够了;
个人用了一年多,使用起来也比较的方便;
项目从10年开源,且作者对外宣称的是永久免费维护下去。所以也不用担心,用着用着,项目死了。
笔记
本教程所有的笔记,我会在个人博客里面整理成一篇文章;大家通过: https://blog.lupf.cn 进入到博客;搜索 “ solo ”关键词即可看到;下面涉及到的每行指令;都会整理进去,方便大家自行搭建的时候使用。
教程的几个简单的章节
Linux虚拟机搭建
本章面向的人群
- 没有云服务器
- 没有linux系统的物理机
- 单纯想测试一下整个教程的可行性
搭建过程
详细教程: https://lupf.cn/articles/2020/04/04/1586001434581.html
- 创建虚拟机
- 配置网络
- 测试外网
- 关闭防火墙
- 修改主机名称
- 安裝vim
- 修改时间
Docker安装
为什么要用Docker
- 跨平台性
- 安装部署简单
- 方便迁移
- 资源隔离,服务与服务之间互不干扰
安装
详细教程: https://lupf.cn/articles/2019/11/23/1574503815568.html
- 安装docker
- 安装docker-compose
基础的镜像准备
mysql
-
创建目录
mkdir -p /opt/docker/mysql
-
下载镜像
docker pull mysql:5.7.13
solo
-
创建目录
mkdir -p /opt/docker/solo
-
下载镜像
docker pull b3log/solo
nginx
由于后面配置ssl证书的时候需要使用到一个朋友定制增强的一个nginx
所以这里一并给下载下来
-
创建目录
mkdir -p /opt/docker/nginx/conf/conf.d mkdir -p /opt/docker/nginx/html mkdir -p /opt/docker/nginx/logs mkdir -p /opt/docker/ohttps-nginx/conf/conf.d mkdir -p /opt/docker/ohttps-nginx/html mkdir -p /opt/docker/ohttps-nginx/logs
-
下载镜像
docker pull nginx docker pull ohttps/ohttps-nginx
-
查看下载的镜像
docker images
博客部署
运行服务
-
准备nginx的默认配置
docker run --name my-nginx -p 80:80 -d nginx docker ps docker cp f79:/etc/nginx/nginx.conf /opt/docker/nginx/conf/nginx.conf docker cp f79:/etc/nginx/conf.d /opt/docker/nginx/conf docker cp f79:/usr/share/nginx/html /opt/docker/nginx docker cp f79:/etc/nginx/nginx.conf /opt/docker/ohttps-nginx/conf/nginx.conf docker cp f79:/etc/nginx/conf.d /opt/docker/ohttps-nginx/conf docker cp f79:/usr/share/nginx/html /opt/docker/ohttps-nginx docker stop f79 docker rm f79
-
准备docker-compose.yml
version: "2" services: mysql: container_name: solo-mysql image: mysql:5.7.13 restart: always volumes: - /opt/docker/solo/mysql/data:/var/lib/mysql - /opt/docker/solo/mysql/logs:/logs - /opt/docker/solo/mysql/conf:/etc/mysql/conf.d - /etc/localtime:/etc/localtime:ro ports: - "3306:3306" environment: MYSQL_ROOT_PASSWORD: "123456" TZ: "Asia/Shanghai" command: --max_allowed_packet=32505856 solo: container_name: solo image: b3log/solo:latest restart: always ports: - "8080:8080" environment: RUNTIME_DB: "MYSQL" JDBC_USERNAME: "root" JDBC_PASSWORD: "123456" JDBC_DRIVER: "com.mysql.jdbc.Driver" JDBC_URL: "jdbc:mysql://solo-mysql:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" command: --listen_port=8080 --server_port= --server_scheme=http --server_host=192.168.1.232 nginx: container_name: solo-nginx image: nginx:latest restart: always ports: - "80:80" - "443:443" volumes: - /opt/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf - /opt/docker/nginx/conf/conf.d:/etc/nginx/conf.d - /opt/docker/nginx/html:/usr/share/nginx/html - /opt/docker/nginx/logs:/var/log/nginx
-
启动服务
此时的启动肯定会报错
因为数据库还没有,还没有创建
docker-compose -f docker-compose.yml up
-
创建数据库
docker ps | grep mysql docker exec -it 容器id /bin/bash mysql -uroot -p create database solo default character set utf8mb4 collate utf8mb4_general_ci; create user 'root'@'127.0.0.1' identified by '123456'; grant all privileges on *.- to 'root'@'127.0.0.1'; flush privileges;
-
调整服务为后台进程
docker-compose -f docker-compose.yml up -d
-
停止并关闭服务
docker-compose -f docker-compose.yml down
-
测试本地方位
http://192.168.1.231:8080
配置nginx
上面运行的服务通过自身监听的端口已经可以访问了;由于默认是监听的8080端口;通常情况下我们是希望通过80或者443端口进行访问的;因此,在这里就部署一个nginx,并监听80或者443端口;然后通过反向代理代理到solo服务去;
-
进入配置文件目录
cd /opt/docker/nginx/conf/conf.d
-
添加配置文件
vim default.conflocation / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $http_host; proxy_pass http://solo:8080; }
https证书的配置
详细的教程:https://lupf.cn/articles/2020/11/21/1605963949092.html
-
注册账号
官网地址:https://www.ohttps.com?invitationCode=dyq1zry5ew07lgn6 -
添加chame记录
参考视频 -
生成证书
-
配置域名解析
参考视频// 刷新dns指令 ipconfig /flushdns
-
添加部署节点(nginx)
-
调整docker-compose
第一处修改 solo服务,--server_scheme修改为https;--server_host=blog.writee.cn
第二处修改;nginx的镜像修改为ohttps/ohttps-nginx
第三处修改;设置nginx自动更新证书的id和token;上面步骤申请到的
第四处修改;修改持久化文件映射的路径
version: "2" services: mysql: container_name: solo-mysql image: mysql:5.7.13 restart: always volumes: - /opt/docker/solo/mysql/data:/var/lib/mysql - /opt/docker/solo/mysql/logs:/logs - /opt/docker/solo/mysql/conf:/etc/mysql/conf.d - /etc/localtime:/etc/localtime:ro ports: - "3306:3306" environment: MYSQL_ROOT_PASSWORD: "123456" TZ: "Asia/Shanghai" command: --max_allowed_packet=32505856 solo: container_name: solo image: b3log/solo:latest restart: always ports: - "8080:8080" environment: RUNTIME_DB: "MYSQL" JDBC_USERNAME: "root" JDBC_PASSWORD: "123456" JDBC_DRIVER: "com.mysql.jdbc.Driver" JDBC_URL: "jdbc:mysql://solo-mysql:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" command: --listen_port=8080 --server_port= --server_scheme=https --server_host=blog.writee.cn nginx: container_name: solo-nginx image: ohttps/ohttps-nginx restart: always ports: - "80:80" - "443:443" environment: PUSH_NODE_ID: "push-1xlpm40g5p85n9gz" PUSH_NODE_TOKEN: "16d2e1584b25bf22888586a51ff86dcf" volumes: - /opt/docker/ohttps-nginx/conf/nginx.conf:/etc/nginx/nginx.conf - /opt/docker/ohttps-nginx/conf/conf.d:/etc/nginx/conf.d - /opt/docker/ohttps-nginx/html:/usr/share/nginx/html - /opt/docker/ohttps-nginx/logs:/var/log/nginx
-
重启服务
docker exec -t 容器id nginx -t docker exec -t 容器id nginx -s reload
-
查看证书
docker ps | grep nginx docker exec -it 容器id /bin/bash cd /etc/nginx/certificates ls
-
nginx配置域名及证书
vim blog.confserver { listen 80; server_name blog.write.cn; return 301 https://$server_name$request_uri; } server { server_name blog.write.cn; listen 443 ssl http2; ssl_stapling on; ssl_stapling_verify on; ssl_certificate_key /etc/nginx/certificates/cert-9dxel0446w04j7o1/cert.key; ssl_certificate /etc/nginx/certificates/cert-9dxel0446w04j7o1/fullchain.cer; ssl_session_timeout 5m; ssl_protocols TLSv1.1 TLSv1.2; ssl_prefer_server_ciphers on; ssl_ciphers "EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5"; ssl_session_cache builtin:1000 shared:SSL:10m; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $http_host; proxy_pass http://solo:8080; } }
标题:基于solo;从0开始搭建个人博客系统(小白保姆级教程)
作者:码霸霸
地址:https://blog.lupf.cn/articles/2020/11/29/1606664585380.html