使用 docker 搭建 solo 博客系统

概述

首先感谢开源,此博客使用的是 solo 博客系统。操作系统是 ubuntu,虚拟化容器 docker,数据库 mysql,java 容器 tomcat,反代 nginx。(不要问什么要用 docker,可能是我有轻微洁癖以及懒,至于为什么有洁癖和懒就要用 docker......)

方法

一、 准备环境

主机和域名,我这里的主机选择亚马逊的 ec2,免备案还能搭梯子,第一年免费。域名从 GoDaddy 买的,绑定域名到 ip

二、 安装 docker-ce

参考官方文档https://docs.docker.com/engine/installation/linux/docker-ce/ubuntu/

三、 安装数据库 myslq:

docker run --name database -e MYSQL_ROOT_PASSWORD=password -v /web/mysql/data:/var/lib/mysql -v /web/mysql/conf:/etc/mysql/conf.d -d mysql:5.7.20

上面的命令在 bash 中执行,第一次会从 docker hub 下载 mysql:5.7.20 这个镜像,所以你的网络要能访问 docker hub。选项说明如下

  • --name database设置容器名称,方便以后引用
  • -e MYSQL_ROOT_PASSWORD=password设置数据库 root 账户密码为 password
  • -v /web/mysql/data:/var/lib/mysql挂载宿主机的 /web/mysql/data 目录到容器的 /var/lib/mysql 目录,因为容器类似于虚拟机,只能把文件存放在自己的文件系统上,我们把宿主机的目录挂载到容器的这个目录上,当容器往 /var/lib/mysql/ 这个目录保存数据文件时,实际会存放在宿主机的 /web/mysql/data/ 目录下。因为容器是可以随时销毁的,无状态的,所以数据不能保存在容器中。(/var/lib/mysql/ 是 mysql 默认的数据存储路径)
  • -v /web/mysql/conf:/etc/mysql/conf.d这样在宿主机的 /web/mysql/conf/ 下的 conf 文件会被数据库读取并应用

详细说明请到 docker hub 上搜索 mysql 查看

四、 配置数据库:

进入数据库容器:docker exec -it database bash
登陆数据库:mysql -uroot -p,输入密码 password,执行下面的语句

CREATE DATABASE `solo` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE USER 'solouser'@'%' identified BY 'solo@pwd';
GRANT ALL ON solo.* TO 'solouser'@'%'; 
FLUSH PRIVILEGES;

五、 下载 solo-2.4.0.war 包

到 github 上找到 solo-2.4.0 的 war 包,下载到 /web/solo/ 目录下

六、 安装 tomcat:

docker run --name tomcat  -p 8080:8080 -v /web/solo:/bitnami/tomcat/data --link database:database -d bitnami/tomcat:9.0

选项说明如下:

  • -p 8080:8080 端口映射,将容器中的 8080 端口映射到宿主机的 8080 端口,因为 tomcat 是在容器中运行,容器类似虚拟器,所以 tomcat 监听的是容器的 8080 端口,所以需要把它映射出来

  • --link database:database 连接数据库容器,第一个 database 是之前创建的容器名,第二个 database 是别名,名称可以随便。目的是为了访问方便,比如两个 tomcat 容器都监听 8080 端口,不可能都映射到宿主机上来吧。这样就可以在 tomcat 容器中访问数据库的 3306 端口了。

  • -ddeamon

七、 设置配置文件并访问

参考solo 用户指南,然后在浏览器中访问你的博客,我的是http://www.dafsic.com:8080/solo-2.4.0, 对数据库进行初始化。为了不加 solo-2.4.0 这样的路径,我将 /web/solo/solo-2.4.0/ 路径下的文件都 mv 到 /web/solo/ROOT/ 路径下了,然后可以http://www.dafsic.com:8080 这样访问

八、 重启 tomcat:

以上没有问题的话,删掉 tomcat 容器,在打开一个新的 tomcat 容器

docker stop tomcat #停容器
docker rm tomcat #删除容器
docker run --name tomcat -v /web/solo:/bitnami/tomcat/data --link database:database -d bitnami/tomcat:9.0 #不映射端口,映射的话,nginx 反代会出现上游服务不能被访问的错误

九、 安装 nginx:

docker run --name nginx -p 80:80 -v /web/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:ro --link tomcat:tomcat -d nginx:1.12.1

选项还是为了覆盖 nginx 的默认配置,以及链接 tomcat。

后记

nginx 最终配置:

user  nginx;
worker_processes  1;
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;
events {
    worker_connections  1024;
}
http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  /var/log/nginx/access.log  main;
    sendfile        on;
    #tcp_nopush     on;
    keepalive_timeout  65;
    #gzip  on;
    upstream backend {
        server tomcat:8080;
    }
    server {
        listen       80;
        server_name  www.dafsic.com;
        access_log off;
        location / {
            proxy_pass http://backend$request_uri;
            proxy_set_header  Host $host:$server_port;
            proxy_set_header  X-Real-IP  $remote_addr;
            client_max_body_size  10m;
        }
    }
}

latke.properties 最终 server 配置:

serverScheme=http
serverHost=dafsic.com
serverPort=80

local.properties 最终数据库部分配置:

runtimeDatabase=MYSQL
jdbc.username=bloguser
jdbc.password=bloguser@pwd
jdbc.driver=com.mysql.jdbc.Driver
jdbc.URL=jdbc:mysql://database:3306/solo?useUnicode=yes&characterEncoding=utf8
jdbc.pool=druid