目 录CONTENT

文章目录

NBlog博客项目部署

小磊
2023-04-25 / 0 评论 / 0 点赞 / 566 阅读 / 3,344 字 / 正在检测是否收录...

我的NBlog博客项目部署

说明

NBlog博客来自Naccl的开源项目,Github地址:Naccl

部署参考资料:如何在服务器部署若依前后端分离版项目码神之路博客部署NBlog部署简介

前置知识

Linux的基本指令,docker基本部署原理,nginx代理,云服务器的购买与基本配置

服务器的购买与安全组设置

我的云配置:华为云2核4GiB服务器,带宽2M,操作系统:Centos 7.9

安全组:由于需要通过外部网络访问因此需要开放一些端口,包括:MySql-3306,Redis-3379(MySql以及Redis注意设置密码,特别是Redis,否则可能会被植入挖矿程序),前台访问接口-80,后台访问接口-7777,后端项目api端口-8888,如果要安装Docker可视化工具Portainer可以开放端口号-9000

无标题

Docker安装,以及镜像拉取

远程连接云服务器,可以使用Xshell或者直接点击服务器管理界面的远程连接,将以下一连串的命令逐步输入到你的命令窗口中

# 1、yum 包更新到最新 
yum update
# 2、安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的 
yum install -y yum-utils device-mapper-persistent-data lvm2
# 3、 设置yum源
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
# 4、 安装docker,出现输入的界面都按 y 
yum install -y docker-ce
# 5、 查看docker版本,验证是否验证成功
docker -v
#启动docker
/bin/systemctl start docker.service
#设置开机自动启动docker
systemctl enable docker

镜像的拉取

docker pull nginx
docker pull redis:6.0.8
docker pull java:8
docker pull mysql:5.7
docker pull portainer/portainer

Docker安装可视化工具Portainer

Portainer可视化工具能够快速实现Docker容器的重启与删除,特别在后续Nginx调试配置文件时十分方便

docker run -d -p 8000:8000 -p 9000:9000 --name portainer --restart=always -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer

Docker安装MySql

构建一个docker来配置MySQL;并将mysql数据文件布置到服务器中,因此需要在服务器中创建文件夹以实现MySql容器卷的挂载

#创建MySql挂载目录并进入
mkdir -p /mnt/docker/mysql
cd /mnt/docker/mysql

运行MySql镜像创建容器

docker run -id -p 3306:3306 --name=mysql -v /mnt/docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=你的MySql密码 mysql:5.7

要进入容器并开放权限,防止后续后端服务连接数据库出错

#进入容器
docker exec -it mysql bash
#进入容器,输入密码并回车确认。(界面上显示空白,但其实密码已经输入了,按回车键确定。)
mysql -uroot -p
#设置权限,
show databases;
use mysql;
show tables;
#执行下面两句时会爆出如下错误--ERROR 1062 (23000): Duplicate entry '%-root' for key 'PRIMARY';可以不用去管它直接继续执行
update user set host ='%'where user ='root';
update user set host ='%'where user ='root' and host='localhost';
grant all privileges on *.* to root@'%' identified by 'root' with grant option;
flush privileges;
#退出MySql客户端
exit
#退出MySql容器
exit

环境无误后我们需要导入我们的数据库文件nblog.sql,该文件在blog-api路径下

上面提到,我们已经将服务器/mnt/docker/mysql/data目录和docker容器的/var/lib/mysql地址之间实现了映射,因此,我们如果将nblog.sql文件导入宿主机的该目录下,nblog.sql同样也会出现在docker的对应目录下,具体操作如下:

#进入目录
cd /mnt/docker/mysql/data
#上传文件,也可以用Xftp直接拖拽上传
rz

接下来在docker中执行该sql

#进入MySql容器
docker exec -it mysql bash
#输入密码,进入docker中的数据库
mysql -uroot -p
#创建数据库
create database nblog;
#退出回到容器
exit
#将文件导入数据库
mysql -uroot -p nblog < nblog.sql;
#切换数据库
use nblog;
#执行sql并保存数据库
source nblog.sql;
#结果检查
use nblog; show tables;

检查结果如下说明数据库配置成功

capture_20220509135240806

Docker安装Redis

Docker安装Redis很简单,如果不需要把Redis的数据持久化直接执行下面语句就可以

docker run -id --name=redis -p 6379:6379 redis:6.0.8 --requirepass "你的Redis密码"

Dockerfile构建后端镜像

诸如MySQL ,redis的镜像我们可以直接拉取,但后端项目的镜像需要我们自己打包,构建

打包前,请修改后端的配置文件-application.properties

#后端服务端口号
server.port=8888

blog.name=test-Blog

blog.api=http://localhost:${server.port}
# 后台管理URL
blog.cms=http://localhost:7777
# 前台界面URL
blog.view=http://localhost:80

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#将localhost改为服务器的公网IP
spring.datasource.url=jdbc:mysql://localhost:3306/nblog?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=GMT%2B8
spring.datasource.username=root
spring.datasource.password=你的MySql密码

#将localhost改为服务器的公网IP
spring.redis.host=localhost
spring.redis.password=你的Redis密码
spring.redis.port=6379
spring.redis.database=0
spring.redis.timeout=10000ms

mybatis.mapper-locations=classpath:mapper/*.xml
mybatis.configuration.map-underscore-to-camel-case=true

logging.level.root=info
logging.level.top.naccl=debug
logging.file=blog-api/log/blog-dev

# 1000 * 60 * 60 * 24 * 3 三天
token.expireTime=259200000
# 生产环境务必修改此配置,否则无法保证token安全性
token.secretKey=abcdefghigklmnopqrseuvexyz

# 博主接收评论提醒方式: Telegram=tg 邮箱=mail (访客评论提醒固定为邮箱方式)
comment.notify.channel=mail
# 新评论是否默认公开
comment.default-open=true

# 如果选择邮箱提醒方式,则会在收到评论后向填写的邮箱自身发送一封邮件(提醒自己);如果选择tg,则填写的邮箱只作为提醒访客的发送方
# 阿里云邮箱,port=25在Windows系统下有效,Linux系统需要改为465并将下面两行取消注释,其它邮箱服务商配置参考关键字"spring mail 服务器"
# spring.mail.properties.mail.smtp.socketFactory.port=465
# spring.mail.properties.mail.smtp.ssl.enable=true
spring.mail.host=smtp.aliyun.com
spring.mail.port=25
spring.mail.username=你的阿里云邮箱地址
spring.mail.password=你的阿里云邮箱密码

# 如果选择邮箱提醒方式,以下可以无需修改
tg.bot.api=https://api.telegram.org/bot
# bot的token,可以从 @BotFather 处获取
tg.bot.token=1234567890:qwertyuiopasdfghjklzxcvbnm
# 自己账号和bot的聊天会话id
tg.bot.chat-id=1234567890
# 是否使用代理
tg.bot.use-proxy=false
# 是否使用反向代理
tg.bot.use-reverse-proxy=true
# 反向代理URL,请自行搭建,示例API随时可能关闭
tg.bot.reverse-proxy-url=https://tg-api-open.naccl.workers.dev

# 代理配置,如不使用无需修改 (目前用于发送Telegram请求)
http.proxy.server.host=127.0.0.1
http.proxy.server.port=7890
http.proxy.server.timeout=10000

# 评论中QQ头像存储方式: 本地:local GitHub:github
upload.channel=github

# 静态文件上传访问路径 Windows环境例如: C:/Users/nblog/Desktop/upload/ Linux环境例如:/home/nblog/upload/
upload.file.path=/home/nblog/upload/
upload.file.access-path=/image/**
upload.file.resources-locations=file:${upload.file.path}

# 如果选择本地上传方式,以下可以无需修改
# GitHub token 教程见 https://naccl.github.io/PictureHosting/#/pictureHosting/help
upload.github.token=ghp_***************************
upload.github.username=你的GitHub账户名
# 需要用作图床的GitHub仓库名
upload.github.repos=static-resources
# 需要上传至仓库的路径 开头需要"/" 结尾不要"/"
upload.github.repos-path=/image

为了区分前台与后台,在所有的后台Controller层加入注释@RequestMapping(“/api”)

需要加入注释的Controller层

capture_20220509144050432

打包后的jar包所在位置

屏幕截图 2022-05-09 161711

将jar包上传至服务器指定文件夹

#创建文件夹
mkdir /mnt/docker/app
#进入文件夹
cd /mnt/docker/app
#将后端jar包上传至当前目录下,并将名字修改为blog_api.jar
rz
mv blog-api-0.0.1.jar blog_api.jar

将blog_api.jar打包为镜像

#新建blog_dockerfile文件
touch blog_dockerfile
#使用vim编译器修改blog_dockerfile文件
vim blog_dockerfile
#将以下内容粘贴进blog_dockerfile即可(个人参数自己修改一下)
FROM java:8
MAINTAINER zhangshidi <zhangshidi@qq.com>
ADD ./blog_api.jar /app.jar
CMD java -jar /app.jar
#使用下面命令查看app镜像是否创建成功
docker images

创建app镜像对应的容器

#执行下面的命令
docker run -id --name=app -p 8888:8888 app

把前端文件上传到服务器中

首先下载并安装HbuilderX,将前端项目导入

上传前需要修改前端文件中的请求后端地址,将/blog-view/src/plugins/axios.js和/blog-cms/src/util/request.js中的baseUrl修改为你的后端 API 地址

//blog-cms/src/util/request.js中的修改如下
const request = axios.create({
	baseURL: 'http://你的服务器公网IP:8888/admin/',
	timeout: 5000
})
//blog-view/src/plugins/axios.js中的修改如下
const request = axios.create({
	baseURL: 'http://你的服务器公网IP:8888/api/',
	timeout: 10000,
})

使用HbuilderX打包前端项目

运行npm run builder分别将前端前台以及后台文件打包,打包后的文件将在dist文件夹下

屏幕截图 2022-05-09 152449

进入dist文件夹将文件夹下所有文件打成一个tar包

前台文件打包结果

capture_20220509153143538

后台文件打包结果

capture_20220509153128003

在服务器上创建前端文件目录,并将打包后的前端文件上传、解压

#创建前端文件夹
mkdir /mnt/nblog/
#进入前端文件夹下
cd /mnt/nblog/
#创建前台文件夹
mkdir blog
#创建后台文件夹
mkdir admin
#进入前台文件夹
cd blog
#将前台dist.tar包上传至当前目录下
rz
#解压
tar -xvf dist.tar
#进入后台文件夹
cd ../admin
#将后台dist.tar包上传至当前目录下
rz
#解压
tar -xvf dist.tar

解压后的前台目录结构

屏幕截图 2022-05-09 154500

解压后的后台目录结构

屏幕截图 2022-05-09 154428

Docker安装Nginx

配置nginx的文件目录以及内部的相关配置文件

#创建nginx挂载目录
mkdir -p /mnt/docker/docker-compose/nginx
#进入目录
cd /mnt/docker/docker-compose/nginx
#创建并修改文件
touch nginx.conf
vim nginx.conf

将下面内容复制进nginx.conf

user root;
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;
    include /etc/nginx/conf.d/*.conf;
}

新建conf.d文件夹,然后新建blog.conf文件

mkdir conf.d
cd conf.d
touch blog.conf
vim blog.conf

将下面内容复制进blog.conf

gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_comp_level 2;
gzip_vary off;

server{
    # 监听端口
    listen  80;
    # 主机名称/地址
    server_name localhost;
    index   index.html;
    # 前端服务
     location / {
        root /nblog/blog/;
        # 刷新页面后跳转到当前页面
        try_files $uri $uri/ /index.html;
        index index.html;
     }
}

server{
    # 监听端口
    listen  7777;
    # 主机名称/地址
    server_name localhost;
    index   index.html;
    # 前端服务
     location / {
        root /nblog/admin/;
        # 刷新页面后跳转到当前页面
        try_files $uri $uri/ /index.html;
        index index.html;
     }
	
}

创建mime.types文件

cd /mnt/docker/docker-compose/nginx
touch mime.types
vim mime.types

将下面的内容复制进去

types {
    text/html                                        html htm shtml;
    text/css                                         css;
    text/xml                                         xml;
    image/gif                                        gif;
    image/jpeg                                       jpeg jpg;
    application/javascript                           js;
    application/atom+xml                             atom;
    application/rss+xml                              rss;

    text/mathml                                      mml;
    text/plain                                       txt;
    text/vnd.sun.j2me.app-descriptor                 jad;
    text/vnd.wap.wml                                 wml;
    text/x-component                                 htc;

    image/png                                        png;
    image/svg+xml                                    svg svgz;
    image/tiff                                       tif tiff;
    image/vnd.wap.wbmp                               wbmp;
    image/webp                                       webp;
    image/x-icon                                     ico;
    image/x-jng                                      jng;
    image/x-ms-bmp                                   bmp;

    font/woff                                        woff;
    font/woff2                                       woff2;

    application/java-archive                         jar war ear;
    application/json                                 json;
    application/mac-binhex40                         hqx;
    application/msword                               doc;
    application/pdf                                  pdf;
    application/postscript                           ps eps ai;
    application/rtf                                  rtf;
    application/vnd.apple.mpegurl                    m3u8;
    application/vnd.google-earth.kml+xml             kml;
    application/vnd.google-earth.kmz                 kmz;
    application/vnd.ms-excel                         xls;
    application/vnd.ms-fontobject                    eot;
    application/vnd.ms-powerpoint                    ppt;
    application/vnd.oasis.opendocument.graphics      odg;
    application/vnd.oasis.opendocument.presentation  odp;
    application/vnd.oasis.opendocument.spreadsheet   ods;
    application/vnd.oasis.opendocument.text          odt;
    application/vnd.openxmlformats-officedocument.presentationml.presentation
                                                     pptx;
    application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
                                                     xlsx;
    application/vnd.openxmlformats-officedocument.wordprocessingml.document
                                                     docx;
    application/vnd.wap.wmlc                         wmlc;
    application/x-7z-compressed                      7z;
    application/x-cocoa                              cco;
    application/x-java-archive-diff                  jardiff;
    application/x-java-jnlp-file                     jnlp;
    application/x-makeself                           run;
    application/x-perl                               pl pm;
    application/x-pilot                              prc pdb;
    application/x-rar-compressed                     rar;
    application/x-redhat-package-manager             rpm;
    application/x-sea                                sea;
    application/x-shockwave-flash                    swf;
    application/x-stuffit                            sit;
    application/x-tcl                                tcl tk;
    application/x-x509-ca-cert                       der pem crt;
    application/x-xpinstall                          xpi;
    application/xhtml+xml                            xhtml;
    application/xspf+xml                             xspf;
    application/zip                                  zip;

    application/octet-stream                         bin exe dll;
    application/octet-stream                         deb;
    application/octet-stream                         dmg;
    application/octet-stream                         iso img;
    application/octet-stream                         msi msp msm;

    audio/midi                                       mid midi kar;
    audio/mpeg                                       mp3;
    audio/ogg                                        ogg;
    audio/x-m4a                                      m4a;
    audio/x-realaudio                                ra;

    video/3gpp                                       3gpp 3gp;
    video/mp2t                                       ts;
    video/mp4                                        mp4;
    video/mpeg                                       mpeg mpg;
    video/quicktime                                  mov;
    video/webm                                       webm;
    video/x-flv                                      flv;
    video/x-m4v                                      m4v;
    video/x-mng                                      mng;
    video/x-ms-asf                                   asx asf;
    video/x-ms-wmv                                   wmv;
    video/x-msvideo                                  avi;
}

Docker创建Nginx容器

docker run -id --name=nginx -p 80:80  -p 443:443 -p 7777:7777-v /mnt/docker/docker-compose/nginx/:/etc/nginx/ -v /mnt/nblog/admin:/nblog/admin -v /mnt/nblog/blog:/nblog/blog nginx 

项目部署完成,验证项目是否正常运行

地址栏输入服务器公网IP,进入前台页面

屏幕截图 2022-05-09 155839

地址栏输入服务器公网IP:7777,进入后台页面

屏幕截图 2022-05-09 155908

0

评论区