服务器部署java项目--Docker+Redis+Nginx+Mysql

服务器搭建docker应用

Docker+Redis+Nginx+Mysql

1、安装docker

#设置安装路径
mkdir /opt/docker
cd /opt/docker

#安装docker
sudo yum -y install docker

#启动docker
sudo systemctl start docker

#查看版本
docker -v

#设置开机自启
systemctl enable docker

2、docker安装nginx

#1 下载nginx镜像
docker pull nginx:latest

#2 查看下载镜像
docker images

#3 创建映射文件目录 (即自定义nginx安装目录)
mkdir root nginx conf

#4 启动nginx
docker run --name nginx -d -p 80:80 nginx

#5 查看是否启动成功
docker ps -a

#6 复制文件到映射目录
#b540be962498是第(5)显示的nginx 的container id
#/root/nginx/conf是第(3)建的映射的路径,需替换成自己的路径。
docker cp b540be962498:/etc/nginx/nginx.conf /root/nginx/conf

# 7停止此nginx,执行:
docker stop nginx

# 8然后再删除nginx容器,执行:
docker rm nginx

# 9重新启动nginx:注意/root/nginx/是第(3)步创建的文件夹路径,需替换自己的。
# 注意这里配置的是docker容器内nginx容器的挂载路径,之后发布前端项目需要在nginx配置文件里配置该挂载路径
docker run --restart=always -d -p 80:80 --name nginx -v /root/nginx/html:/usr/share/nginx/html -v /root/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /root/nginx/logs:/var/log/nginx nginx

# 10查看是否启动成功:若有nginx并且status是up则启动成功。
docker ps -a 

# 11修改nginx.cong配置:
# 在修改nginx配置文件之前需要先导入前后端项目文件包
# 进入conf:cd /root/nginx/conf,修改了nginx.conf后,停止nginx然后重启即可生效。
# 停止
docker stop nginx
#启动
docker start nginx

3、docker 安装 Mysql

#1、下载MySQL
docker pull mysql:latest

#2、查看是否下载成功
docker images

#3、建文件夹,用于挂载数据,防止容器停止,数据丢失
mkdir conf logs data

#4、启动MySQL,/root/mysql/conf、logs、data为第3步建的文件夹的路径,换成自己的路径即可,
#MYSQL_ROOT_PASSWORD=xxxx是root用户的密码
docker run --name mysql -v /root/mysql/conf:/etc/mysql/conf.d -v /root/mysql/logs:/logs -v /root/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=xxxxx -d -i -p 3306:3306 mysql

#5、查看mysql启动:看到mysql并且STATUS是 up,则mysql启动成功
docker ps -a

#6、测试连接,mysql为容器名,即第4步的--name mysql
docker exec -it mysql bash

#7、输入密码,即第4步设置的密码
mysql -u root -p

#8、登录成功后,显示数据库
show databases

#9、退出数据库
exit

#10、退出docker
exit

4、docker安装Redis (非必要)

#下载Redis镜像
docker pull redis:latest

#查看下载镜像
docker images

#启动Redis
docker run -p 6379:6379 --name redis -v /root/redis/redis.conf:/etc/redis/redis.conf -v /root/redis/data:/data -d --restart=always redis redis-server /etc/redis/redis.conf --appendonly yes --requirepass "1234567890"

#查看是否启动成功
docker ps -a

#命令注解
-v /root/redis/redis.conf:/etc/redis/redis.conf
挂载Redis的配置文件,/root/redis/是自己创建的文件路径。

-v /root/redis/data:/data,挂载Redis的数据,即使Redis重启数据不会丢失。

--restart=always,设置docker启动会自动启动Redis。

redis-server /etc/redis/redis.conf --appendonly yes,数据持久化。

--requirepass "1234567890",设置密码。

5、构建后端应用镜像

(1)准备

  • 在服务器建一个文件夹,文件夹名和将要构建镜像名称一致即可,方便管理,用于保存Dockerfile和jar包。这里就建一个test文件夹为例
#建文件夹
mkdir test
  • Dockerfile

​ 在test文件夹建Dockerfile文件

#1、建Dockerfile文件
touch Dockerfile

#Dockerfile内容:
FROM java:8
VOLUME /tmp
EXPOSE 8080
COPY test.jar test.jar
ENTRYPOINT ["java","-jar","test.jar"]

#2、把下面的Dockerfile内容复制进来
# 编辑文件
vi Dockerfile

#保存退出
:wq
  • 打包spring boot项目为jar包

​ **注意:项目里的数据库、Redis的连接IP用服务器的内网IP,必须是内网IP。**除非把MySQL和Redis给放开让外 网访问,可以换成公网IP,但不建议如此做,这是不安全的。
​ 把项目打包成jar包后,上传到服务器的test目录,即Dockerfile和jar包同在一目录。

mac上传项目文件命令:

scp /本地路径/xxxx.jar root@ip地址:/服务器test路径/test
#例子:scp /Users/sakura/Downloads/test/test.jar root@192.168.0.1:/root/test
#然后输入服务器登录密码

windows上传文件:

通过jumpserver/xshell上传即可

若通过jumpserver浏览器端,可以先将jar包上传到tmp文件夹下,然后使用复制命令 cp [源文件] [目标路径]

cp /tmp/test.jar /opt/project/test #把tmp目录下的test.jar文件复制到opt/project/test目录下

(2)构建镜像

进入test目录,然后执行构建命令,注意test后面有个点的,不要漏掉。

#test为镜像名称
docker build -t test .

#查看镜像
docker images

#构建成功后启动容器
#--name test 容器名称,/root/logs:/logs日志挂载到磁盘
#/root/logs磁盘路径,/logs为应用保存日志的相对路径
docker run --name test -d -p 8080:8080-v /root/logs:/logs test

#启动完成后可以查看具体情况
#查看日志,test为容器名
docker logs test

#查看容器启动状态,status为up则启动正常
docker ps -a

6、发布前端

以Vue项目为例,在本地项目中执行以下命令构建Vue项目

npm run build

构建完成后会有一个dist文件夹,压缩。在第4步安装nginx有个html挂载文件夹,在html文件夹下再建一个前端文件夹

test-page,把dist压缩包上传到test-page里,解压缩,注意解压缩后有个index.html文件,这个文件必须在test-page

里,不能是在子级目录,不然nginx配置会不准确。

7、配置nginx

此时前后端都已经准备好了,就差配置nginx了。

#进入nginx的conf目录
cd /nginx/conf
#编辑nginx.conf文件
vi nginx.conf

然后把下面配置添加到你的nginx配置

  • 监听的是80端口

  • 把192.168.0.1换成服务器的内网IP(即后端项目访问IP),/api/为后端接口的映射前缀,所以前端访问后端接口时都要加上这个前缀,当匹配到时转发到后端应用。

  • 然后配置前端,根路径即是前端首页,需要注意的是root 的路径是docker容器内nginx容器挂载前端项目的路径,并不是服务器本地挂载的路径。

user  nginx;
worker_processes  auto;

error_log  /var/log/nginx/error.log notice;
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;
    server {
        listen 80;
        server_name localhost;

    location /api/ {
        proxy_pass http://192.168.0.1:8080/; 
    }
    location / {
        root /usr/share/nginx/html/test-page;
        index index.html index.htm;
    }
    }

    include /etc/nginx/conf.d/*.conf;
}
#保存后重启nginx
#停止nginx
docker stop nginx

#启动nginx
docker start nginx

小结:站在巨人的肩膀上实战演练的笔记呀,巨人链接https://www.jianshu.com/p/016fb74db819?u_atoken=cab7e872-0e6b-40fa-8de0-8feabe4d29bf&u_asession=01rJmwPZOyatG4W80vwQtPK7a64BMyK40PbXrXIP1r1R7hM610YQU4Kyi_F028WD10X0KNBwm7Lovlpxjd_P_q4JsKWYrT3W_NKPr8w6oU7K9wPZHi7SJ0HQ4NMxpErFhUnHmbkqVcEgdObpAroqY1_GBkFo3NEHBv0PZUm6pbxQU&u_asig=05wanIMMdgd47zVbFsycM4G58uqE8FPI-_SwVxxVexOq34WOLMCSj2gnlD9DcWPWr-aeXHiDvf-r5dmX50SzAWSs27079xEPvwOdqT3k24rUn56lgTEHVryYKgTHriPvdleyGS42rONIgioPxFTjUjrdpFYKB4OMAb_WPu4nce8vL9JS7q8ZD7Xtz2Ly-b0kmuyAKRFSVJkkdwVUnyHAIJzZ4kSasBz8EdRYXcBB2IG5ZOhTYlHdKRZzSxl8h7pDKj6xbSxAaWh9ph0bRUFW-6vO3h9VXwMyh6PgyDIVSG1W8YBmBS57ddC3xWbn6wJf8CGfXX_4EbeDdDbat77LpkgVKaZKt8azkQ42hsIzXDMRxAgtdg-Dvf9f3Qia2ZmRb2mWspDxyAEEo4kbsryBKb9Q&u_aref=L5z5em%2B76LZcSuRcjWUKC6JFegs%3D

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
运维项目经验是很宝贵的,以下是基于Nginx+Nacos+MySQL+Redis+RabbitMQ的运维项目经验: 1. Nginx Nginx是一款高性能的Web服务器和反向代理服务器。在运维过程中,需要对Nginx进行配置和监控,以确保其运行稳定。 - 配置 Nginx配置文件的路径为"/etc/nginx/nginx.conf",可以使用编辑器进行修改,如vi、nano等。在配置文件中,需要注意以下几点: - worker_processes:指定工作进程数,一般根据CPU核心数进行设置。 - pid:指定进程ID的存储路径。 - error_log:指定错误日志的存储路径。 - access_log:指定访问日志的存储路径。 - http:指定HTTP协议的配置项,如代理服务器、缓存等。 - server:指定服务器的配置项,如监听端口、域名等。 - 监控 可以使用Nginx自带的状态模块,通过访问"http://localhost:8080/nginx_status"来获取Nginx的状态信息。也可以通过第三方监控工具进行监控,如Zabbix、Grafana等。 2. Nacos Nacos是一款开源的服务发现、配置管理和动态DNS解析系统。在运维过程中,需要对Nacos进行部署和配置,以确保其正常运行。 - 部署 Nacos的部署可以使用Docker、Kubernetes等容器化技术进行部署,也可以直接下载二进制包进行部署。在部署过程中,需要注意以下几点: - 需要占用的端口:Nacos默认使用8848端口。 - 数据库配置:Nacos需要使用MySQL或者MariaDB作为数据存储的后端,需要进行相关的数据库配置。 - 配置文件的修改:Nacos的配置文件位于conf目录下,可以根据实际情况进行修改。 - 配置 在Nacos中,需要进行以下配置: - 服务注册:通过Nacos的API,将需要注册的服务注册到Nacos中。 - 配置管理:将需要管理的配置文件上传到Nacos中,并设置相应的命名空间、数据ID和分组。 3. MySQL MySQL是一款流行的关系型数据库管理系统。在运维过程中,需要对MySQL进行配置和监控,以确保其运行稳定。 - 配置 MySQL的配置文件的路径为"/etc/my.cnf",可以使用编辑器进行修改,如vi、nano等。在配置文件中,需要注意以下几点: - port:指定MySQL的监听端口。 - bind-address:指定MySQL的监听地址。 - max_connections:指定MySQL的最大连接数。 - log-error:指定错误日志的存储路径。 - slow-query-log:指定慢查询日志的存储路径。 - 监控 可以使用MySQL自带的状态变量和性能指标,通过执行"SHOW STATUS"和"SHOW VARIABLES"语句来获取MySQL的状态信息。也可以通过第三方监控工具进行监控,如Zabbix、Grafana等。 4. Redis Redis是一款高性能的内存数据库。在运维过程中,需要对Redis进行配置和监控,以确保其运行稳定。 - 配置 Redis的配置文件的路径为"/etc/redis/redis.conf",可以使用编辑器进行修改,如vi、nano等。在配置文件中,需要注意以下几点: - bind:指定Redis的监听地址。 - port:指定Redis的监听端口。 - daemonize:指定Redis是否以守护进程的方式运行。 - logfile:指定Redis的日志文件路径。 - maxclients:指定Redis的最大连接数。 - 监控 可以使用Redis自带的命令,如"INFO",来获取Redis的状态信息。也可以通过第三方监控工具进行监控,如Zabbix、Grafana等。 5. RabbitMQ RabbitMQ是一款开源的消息队列系统。在运维过程中,需要对RabbitMQ进行部署和配置,以确保其正常运行。 - 部署 RabbitMQ的部署可以使用Docker、Kubernetes等容器化技术进行部署,也可以直接下载二进制包进行部署。在部署过程中,需要注意以下几点: - 需要占用的端口:RabbitMQ默认使用5672端口。 - 用户名和密码:在RabbitMQ中,需要使用用户名和密码进行身份验证,需要进行相应的用户配置。 - 配置 在RabbitMQ中,需要进行以下配置: - 队列的创建:通过RabbitMQ的API,创建需要使用的队列。 - 交换机的创建:通过RabbitMQ的API,创建需要使用的交换机。 - 路由键的绑定:通过RabbitMQ的API,将队列和交换机进行绑定,并指定相应的路由键。 总体来说,基于Nginx+Nacos+MySQL+Redis+RabbitMQ的运维项目经验需要对以上组件进行深入理解和熟练掌握,才能更好地进行运维管理。在实践中,需要不断积累经验和总结,以便能够更好地应对各种问题和挑战。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xzh_2022

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值