利用 solo 搭建个人博客

本贴最后更新于 1348 天前,其中的信息可能已经时移世异

参考链接:
Solo 用户指南
从零开始安装 solo 博客


2021.04.16 ,当时留了太多坑了,现在重写一遍

搭建前提

  • 购买服务器
  • 购买域名(可不买)
  • 域名解析与备案
  • 为服务器安装系统

安装 docker

我的系统,Centos7.3

#使用yum更新仓库
yum update

#安装docker
yum -y install docker

#启动 Docker 后台服务
service docker start

#测试运行 hello-world
docker run hello-world

出现 hello world 就证明安装正常了

安装 MySQL

版本随意,我这里选择的 5.6,你可以选择更高版本的,这个没关系,不影响使用

提供两种方式

直接安装 mysql(方式一,推荐)

根据自己的系统环境直接百度吧。

安装完成之后新建 solo 数据库

create database solo DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

docker 安装 mysql(方式二)

# 安装mysql:5.6,直接docker run 他会自动去官方镜想下载
# MYSQL_ROOT_PASSWORD=你的数据库密码
docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6

# docker安装的mysql默认允许远程连接,可以使用xshell等软件连接数据库
# 进入容器mysql
docker exec -it mysql bash

# 进入数据库 p后面跟你的密码
mysql -uroot -p123456

# 创建数据库(数据库名:solo;字符集utf8mb4;排序规则utf8mb4_general_ci)
create database solo DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
# 出现Query OK, 1 row affected (0.00 sec)表示成功
#退出数据库
exit
#退出容器
exit

备份 SQL 文件的时候,可以通过 sqlyog 远程连接来备份。

当需要挂载本地目录(数据卷)到 docker 容器的时候,运行下面语句创建 MySQL 容器,这样可以使数据持久化,当将容器删除时,数据不会丢失。

docker run --name mysql -p 3306:3306 \
-v /dockerData/mysql/data:/var/lib/mysql \
-v /dockerData/mysql/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf \
-e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6
  • -v /dockerData/mysql/data:/var/lib/mysql:将本地数据卷挂载到 MySQL 容器
  • -v /dockerData/mysql/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf:将本地配置挂载到 MySQL 容器(配置中添加了 MySQL 内存优化的语句)

关于远程无法连接 mysql

先打开防火墙 3306 端口。

给 root 用户授权,允许远程链接。

# 授权
grant all privileges on *.* to 'root'@'%';
# 刷新授权
flush privileges;

安装 solo

直接运行以下命令

docker run --detach --name solo --network=host \
--env RUNTIME_DB="MYSQL" \
--env JDBC_USERNAME="root" \
--env JDBC_PASSWORD="123456" \
--env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \
--env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \
--rm \
b3log/solo --listen_port=8080 --server_scheme=http --server_host=www.rainsheep.cn

上面的命令建议手敲,免得出错,参数说明

  • --network=host 让 solo 容器使用 docker 的 host 网络模式,使容器之间网络互通
  • --env JDBC_PASSWORD="123456" 将 123456 换成你的密码
  • --listen_port=8080 监听的端口
  • --server_scheme=http 请求方式,暂时使用 http,后面我们会换成 https
  • --server_host=www.rainsheep.cn 你的域名,如果你没有域名可以写 ip 地址
  • --rm 因为这个容器后面要删掉,带上 rm 会省很多事。

命令成功执行没有报错的话,通过 docker ps 查看执行的容器列表中是否存在 solo,存在这表示启动成功,直接访问你的域名加:8080 即可访问你的博客,http://www.rainsheep.cn:8080
如果你尚在备案中,你可以收藏本帖,后面等备案通过了在研究后面的部分。
如果你不想使用 nginx 也不想升级 https,那么你可以先执行 docker stop solo ,然后将上面 --listen_port=80808080 换成 80 ,然后去掉 --rm ,再执行一次就 ok。

进入网页可能会出现 Latke 配置错误,如果要配置 nginx 反代理的话不需要管,配完就好了
如果不配置反代理的话,在后面加上参数 --server_port=8080 或者 --server_port=80 ,与前面监听端口一致

安装 nginx

直接安装(方式一,推荐)

根据自己系统环境百度安装即可。

docker 安装(方式二)

# 切换到服务器根目录
cd /
# 创建主目录
mkdir dockerData
# 创建文件
mkdir dockerData/nginx dockerData/nginx/conf dockerData/nginx/logs dockerData/nginx/www dockerData/nginx/ssl

上面的 dockerData 可以换成自己喜欢的名字

  • dockerData/nginx 用于存放 docker 下 nginx 自定义文件
  • dockerData/nginx/conf 存放 nginx 配置文件
  • dockerData/nginx/log 存放 nginx 日志文件
  • dockerData/nginx/www 存放 nginx 访问的资源文件
  • dockerData/nginx/ssl 存放 ssl 证书

启动 nginx
docker run --name nginx -p 80:80 -d --rm --network=host nginx

如果你没有备案,可以将上面的 80:80 换成 8081:80 ,表示将本地的 8081 端口映射到容器内部的 80 端口,因为这个东西一会儿也要删掉,所以加上 --rm 参数,命令执行玩后通过 docker ps 查看 nginx 是否在运行,在运行的情况下访问你的域名加端口号查看是否正常安装, 80 直接省略。访问出现 Welcome to nginx!表示成功。

导出配置文件

  • docker cp nginx:/etc/nginx/nginx.conf /dockerData/nginx/conf/nginx.conf 导出配置文件 nginx.conf

执行 docker stop nginx ,会自动删除现在的 nginx 容器,然后执行如下命令重新启动一个 nginx 容器

docker run -dit -p 80:80 --name nginx --network=host \
-v /dockerData/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /dockerData/nginx/www:/usr/share/nginx/html \
-v /dockerData/nginx/logs:/var/log/nginx nginx
  • -v /dockerData/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \ 挂载配置文件 nginx.conf
  • -v /dockerData/nginx/www:/usr/share/nginx/html 挂载项目文件
  • -v /dockerData/nginx/logs:/var/log/nginx 挂载配置文件
  • -dit 可以防止 nginx 容器自动关闭

新建欢迎界面

# 打开项目文件 
cd /dockerData/nginx/www 
# 使用vim 创建并编辑文件
vim index.html 
# 此时我们会进入vim界面,按 i 插入,然后输入 
<h1>Hello Docker-Nginx</h1> 
# 输入完后,按 esc,然后输入 :wq

访问域名,可看到 Hello Docker-Nginx

申请 ssl 证书,将 http 升级为 https(可跳过)

申请完 ssl 证书以后,下载证书
最后把 Nginx 下的两个文件上传至服务器 /dockerDat/nginx/ssl 目录下

我的两个证书名字为 3118615_rainsheep.cn.pem3118615_rainsheep.cn.key

配置 nginx 配置文件

使用 docker 安装的话:

cd /dockerData/nginx/conf
vim nginx.conf

自己直接安装的话:找到 nginx 的配置文件 nginx.conf 进行修改

参考我的配置,配置自己的 nginx.conf 文件

worker_processes  1;


events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;

    # 负载均衡
    upstream backend {
        server localhost:8080;
    }

    # http跳转https
    server {
        listen       80;
        server_name  *.rainsheep.cn;
        rewrite ^(.*)$ https://$host$1 permanent;
    }

    # solo blog
    server {
        listen 443 ssl;
        server_name  www.rainsheep.cn;
        access_log off;

        ssl_certificate /ssl/3783689_www.rainsheep.cn.pem;
        ssl_certificate_key /ssl/3783689_www.rainsheep.cn.key;
        ssl_session_timeout 5m;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
        ssl_prefer_server_ciphers on;

        location / {
            proxy_pass http://backend$request_uri;
            proxy_set_header  Host $http_host;
            proxy_set_header  X-Real-IP  $remote_addr;
            client_max_body_size  10m;
        }
    }
}

直接安装 nginx 则不需要进行下列步骤

由于我们现在用的 nginx 容器并未监听 443 端口,所以需要删除现在的容器,重新启动一个新的 nginx 容器

docker stop nginx  # 停止容器
docker rm nginx # 删除容器
# 启动新的
docker run -d -p 80:80 -p 443:443 --name nginx --network=host \
-v /dockerData/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /dockerData/nginx/ssl:/ssl/ \
-v /dockerData/nginx/www:/usr/share/nginx/html \
-v /dockerData/nginx/logs:/var/log/nginx nginx
  • -p 443:443 监听 443 端口
  • -v /dockerData/nginx/ssl:/ssl/ 挂载 ssl 证书目录

访问查看,正常访问

访问不到的话,可能是配置文件错了,仔细核对, docker logs nginx 查看日志, docker ps 查看是否运行。

将 solo 通过 nginx 方向代理实现 https 访问

让 solo 还是跑在 8080 端口上,通过 nginx 代理到 443 端口即可,由于我们上面启动 solo 时添加了 --rm 参数,只需要 docker stop solo 即可自动删除 solo 容器,然后我们重新启动一个 solo 容器

docker run --detach --name solo --network=host \
--env RUNTIME_DB="MYSQL" \
--env JDBC_USERNAME="root" \
--env JDBC_PASSWORD="123456" \
--env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \
--env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \
b3log/solo --listen_port=8080 --server_scheme=https --server_host=www.rainsheep.cn --server_port=
  • --server_scheme=http 换成 --server_scheme=https 即可
  • --server_port :最终访问端口,使用浏览器默认的 80 或者 443 的话值留空即可

重启 nginx, docker restart nginx
访问成功。

启用 Lute

  • 获取最新镜像 docker pull b3log/lute-http
  • 启动容器 docker run --detach --rm --network=host --name="lute" b3log/lute-http
  • 停止 solo, docker stop solo
  • 删除 solo,docker rm solo
  • 运行下列命令,重启 solo,注意最后添加 --lute_http=http://127.0.0.1:8249
docker run --detach --name solo --network=host \
--env RUNTIME_DB="MYSQL" \
--env JDBC_USERNAME="root" \
--env JDBC_PASSWORD="123456" \
--env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \
--env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \
b3log/solo --listen_port=8080 --server_scheme=https --server_host=www.rainsheep.cn --server_port= --lute_http=http://127.0.0.1:8249
  • 容器启动成功后再启动 Solo、Pipe、Sym 即可,如果成功的话 Solo 等的启动日志中 docker logs solo 会输出 luteAvailable=true

测试代码是否高亮。
教程结束。

启用 jsDelivr CDN 加速

docker run --detach --name solo --network=host \
--env RUNTIME_DB="MYSQL" \
--env JDBC_USERNAME="root" \
--env JDBC_PASSWORD="123456" \
--env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \
--env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \
b3log/solo --listen_port=8080 --server_scheme=https --server_host=www.rainsheep.cn --server_port= --lute_http=http://127.0.0.1:8249 \
--static_server_scheme=https \
--static_server_host=cdn.jsdelivr.net \
--static_server_port= \
--static_path=/gh/88250/solo/src/main/resources

查看方法:打开开发者工具,查看 NetWork 中的请求链接地址。

仅支持内置皮肤

solo 自动更新脚本

利用 crontab 运行脚本自动更新,脚本名 docker-solo-update.sh

如果不想自动更新的话,自行运行脚本即可手动更新,建议手动更新

#!/bin/bash
echo -e "\n"
echo `date "+%Y-%m-%d %H:%M:%S"`
isUpdate=$(docker pull b3log/solo|grep "Downloaded")
if [ -z  $isUpdate ]
then
    echo This is the latest version
else
    docker stop solo
    docker rm solo
    docker run --detach --name solo --network=host \
    --env RUNTIME_DB="MYSQL" \
    --env JDBC_USERNAME="root" \
    --env JDBC_PASSWORD="123456" \
    --env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \
    --env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \
    b3log/solo --listen_port=8080 --server_scheme=https --server_host=www.rainsheep.cn --server_port= --lute_http=http://127.0.0.1:8249 \
    --static_server_scheme=https \
    --static_server_host=cdn.jsdelivr.net \
    --static_server_port= \
    --static_path=/gh/88250/solo/src/main/resources
    echo Success!
fi

使用方法:
chmod 777 docker-solo-update.sh
crontab -e
写入
0 3 * * * bash /root/docker-solo-update.sh
需要打印日志信息的话
0 3 * * * bash /root/docker-solo-update.sh >> /root/sololog.log 2>&1
运行
crontab -l
查看是否插入成功

Lute 自动更新脚本

利用 crontab 运行脚本自动更新,脚本名 docker-lute-update.sh

#!/bin/bash
echo -e "\n"
echo `date "+%Y-%m-%d %H:%M:%S"`
isUpdate=$(docker pull b3log/lute-http|grep "Downloaded")
if [ -z  $isUpdate ]
then
    echo This is the latest version
else
    docker stop lute
    docker run --detach --rm --network=host --name="lute" b3log/lute-http
    echo Success!
fi

使用方法:
chmod 777 docker-lute-update.sh
crontab -e
写入
0 4 * * * bash /root/docker-lute-update.sh
需要打印日志信息的话
0 4 * * * bash /root/docker-lute-update.sh >> /root/lutelog.log 2>&1
运行
crontab -l
查看是否插入成功

导入 .md 文件

参考链接:
Solo 支持 Hexo/Jekyll 数据导入

--volume 待导入目录/:/opt/solo/markdowns/ 这样应该就可以了,其中 待导入目录 是你寄主机上的绝对路径。

例如:

docker stop solo
docker rm solo
docker run --detach --volume /root/solo-markdown/:/opt/solo/markdowns/ --name solo --network=host \
--env RUNTIME_DB="MYSQL" \
--env JDBC_USERNAME="root" \
--env JDBC_PASSWORD="123456" \
--env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \
--env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \
b3log/solo --listen_port=8080 --server_scheme=https --server_host=www.rainsheep.cn --server_port= --lute_http=http://127.0.0.1:8249

过程中需要用到的 docker 命令
docker ps 查看运行的容器
docker ps -a 查看所有容器
docker stop id||name 停止容器
docker rm id||name 移除容器
docker logs 容器名 查看容器日志

MySQL 的内存优化

直接安装的话

找到配置文件,尾部添加

performance_schema_max_table_instances=400
table_definition_cache=400
table_open_cache=256

docker 安装的话

输入命令 top 可以查看内存使用情况。

优化 MySQL 所占内存:

创建文件夹

cd /dockerDate
mkdir mysql

从容器中复制配置文件到服务器
docker cp mysql:/etc/mysql/mysql.conf.d/mysqld.cnf /dockerData/mysql

编辑配置文件
vim mysqld.cnf

末尾添加

performance_schema_max_table_instances=400
table_definition_cache=400
table_open_cache=256

从服务器复制到容器
docker cp /dockerData/mysql/mysqld.cnf mysql:/etc/mysql/mysql.conf.d/mysqld.cnf

改完之后记得重启 MySQL
docker restart mysql

双博客

如果想在一个服务器搭建两个博客。

docker run --detach --name solo2 -p 8090:8090 \
--env RUNTIME_DB="MYSQL" \
--env JDBC_USERNAME="root" \
--env JDBC_PASSWORD="123456" \
--env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \
--env JDBC_URL="jdbc:mysql://39.105.149.231:3306/solo2?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \
b3log/solo --listen_port=8090 --server_scheme=https --server_host=seeker.rainsheep.cn --server_port= --lute_http=http://39.105.149.231:8249 \
--static_server_scheme=https \
--static_server_host=cdn.jsdelivr.net \
--static_server_port= \
--static_path=/gh/88250/solo/src/main/resources
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1436 引用 • 10056 回帖 • 489 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖
1 操作
Rainsheep 在 2021-04-16 16:52:33 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • csfwff 1

    🤔 🤔 🤔 亲,按你的 nginx 配置真的能访问到你的博客咩

  • 其他回帖
  • SherlockOuO

    请问,域名备案还没完成怎么搞

    2 回复
  • someone
    作者

    额 我今天刚配完 留个教程......主要自己看

  • Rainsheep

    这里面是以前的,你可以进我博客查看我现在改进的教程

  • 查看全部回帖