Docker安装solo博客部署到云服务器教程

Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着很是活跃的社区,可将文章做为帖子推送到社区,来自社区的回帖将做为博客评论进行联动html

总的来讲,这款博客框架还不错,社区也在不断的完善。最重要的是使用Java写的。像流行的Hexo、Hugo等博客框架都是静态博客,没有后台啥的,主要发表的文章是Markdown转HTML格式的形式发表的,但solo是有后台管理的,与Jpress有些类似。java

1. Docker 部署

docker pull b3log/solo
  • 启动容器
  • 注意:对于以下命令,若是你不肯定如何使用 \ 来进行换行,就不要换行了,一行内写完整条命令。
  • 使用 MySQL
  • 手动建库(库名 solo ,字符集使用 utf8mb4 ,排序规则 utf8mb4_general_ci ):
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;
  • 打开服务器上的mysql,一条一条执行便可
  • 注意:上面的密码指mysql的root用户密码
  • 启动容器:
    在这里插入图片描述
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&allowPublicKeyRetrieval=true" \
    b3log/solo --listen_port=6000 --server_scheme=http --server_host=localhost --server_port=
  • 启动参数说明:
    --listen_port:进程监听端口,能够自定义修改
    --server_scheme:最终访问协议,若是反代服务启用了 HTTPS 这里也须要改成 https
    --server_host:最终访问域名或公网 IP,不要带端口
    --server_port:最终访问端口,使用浏览器默认的 80 或者 443 的话值留空便可
    完整启动参数的说明可使用 -h 来查看。
  • 注意:JDBC_PASSWORD 也是指云服务器上mysql的root用户密码
  • 注意--listen_port,我这边设置监听的端口号是6000,官方给的是8080端口,由于我这边服务器上的8080端口已经被Tomcat占用了,因此放行 6000 端口的防火墙,也能够自定义其余端口号(在不冲突的状况下,也就是肯定没有其余进程在使用),开启防火墙端口号的命令以下:
firewall-cmd --zone=public --add-port=6000/tcp --permanent

firewall-cmd --reload

firewall-cmd --zone=public --list-ports
  • 也要在服务器上的安全组上放行 6000 端口
  • 执行启动容器后,可使用以下命令观察容器进程的变化
docker ps -a
  • 也可使用打印solo的日志来观察时候安装成功
docker logs solo
  • 当看到这条日志时,表示solo正在建立表和初始化
    在这里插入图片描述

2. 日志配置

  • 默认经过 log4j2 将日志打印到标准输出流,能够经过 docker logs solo 进行查看。若是须要覆盖 log4j 配置,可经过挂载文件实现:
--volume ~/log4j2.xml:/opt/solo/log4j2.xml
  • 挂载第三方皮肤
    若是须要使用第三方皮肤,能够挂载目录 skins,目录结构请参考原版 skins
--volume ~/skins/:/opt/solo/skins/

3. Nginx 反向代理

  • 在nginx的安装目录conf文件夹下的nginx.conf文件添加以下:
upstream backend {
    server localhost:6000; # Solo 监听端口
}

server {
    listen       80;
    server_name  solo.xdr630.com; # 博客域名

    access_log off;

    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;
    }
}
  • 这边监听的6000端口号就是上面solo进程所须要的的端口号
  • 添加完成后重载配置使其生效
nginx -s reload
  • 接着访问登陆后台就可使用了:http://solo.xdr630.com/
    在这里插入图片描述mysql

  • 能够看到,主题仍是比较多的,也能够在设置移动端的皮肤,或添加看板娘之类的。
    在这里插入图片描述nginx

  • 有关更细致的对solo博客的了解请访问官网。程序员

相关文章
相关标签/搜索