mall 阿里云部署

前言:虽然在部署成功后,基本后台都是热部署,但是在开发过程中,部署的次数还是很多的,所以说非常需要像K8s或者jenkins,来完成一键部署,否则在在开发中手动完成,在测试过程中就会让人头秃了。

1.项目源代码部署过程中需要修改的地方。

修改mall/mall-admin/src/main/resources/application.yml

spring:
profiles:
active: dev #默认为开发环境

spring:
profiles:
active: prod #默认为开发环境

修改application-prod.yml
中数据库的用户名和密码,和数据库中设置的一致。

还有search和portal中的也要修改。

portal中的pom.xml需要修改relativePath,不知道为什么这个找不到父项目的pom
<parent>
<groupId>com.macro.mall</groupId>
<artifactId>mall</artifactId>
<version>1.0-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>

2.使用IDEA直接部署到服务器。

(1.)使用Maven插件将SpringBoot应用打包为Docker镜像,并上传到自己在服务器上建的私有镜像仓库Docker Registry。
dockerHost使用本地的ip地址,这种方法只能使用在本地电脑上。

(2.)在IDEA中使用Alibaba Cloud Toolkit直接部署在ECS上。
服务器上的环境相当复杂,参考https://help.aliyun.com/KnowledgeDetail.htm?spm=5176.2020520129.113.2.35c146aea5YLeE&knowledgeId=96088



参考这篇文章https://yq.aliyun.com/articles/680157
用这个方法需要禁用pom.xml中的
spotify,不然会有冲突。
多么模块的spring boot 项目还需要参考这篇文章https://help.aliyun.com/document_detail/100310.html?spm=a2c4g.11186623.6.571.5fad4909ZsfkKU
也就是在子模块中增加一个maven goal 的命令 clean package命令。
不然多么模块的会出现找不到pom文件的错误。

(3.)在阿里云上建立私有仓库配合Docker Compose 进行部署。

由于需要在本地安装docker。

mac 的话,https://www.docker.com/products/docker-desktop,这个是下载地址。

安装完执行这条命令

docker run -d -v /var/run/docker.sock:/var/run/docker.sock -p 2376:2375 \ bobrik/socat TCP4-LISTEN:2375,fork,reuseaddr UNIX-CONNECT:/var/run/docker.sock
 
如果没有安装socat的话需要安装,brew install socat,就安装完了。
(这两条命令参考了 https://my.oschina.net/u/2306127/blog/777695,其实说白了不是参考,是抄的。)

之后就是IDEA 连接阿里云的私有docker 仓库了(参考https://blog.csdn.net/dahai2070/article/details/84256229

  「1」IDEA plugins 安装 docker integration插件。

  「2」

  由于在第一步设置docker 端口监听的时候设置的是2376转2375,所以在这里要设置为2376.

  

然后在阿里云上申请docker registry,参考上面的那个链接就可以了。

这个密码不是登陆密码,是开通docker registry 时候的密码,我忘了是怎么设置的了。

再在命令行中push到仓库。

这个方法需要再手动从服务端pull下来镜像,感觉很麻烦就没有使用。

经过上面的步骤mall的三个模块admin,portal,search都已经用上传到IDEA上传到阿里云了,接下来就是怎么弄docker了。

elasticsearch

  • 需要创建/mydata/elasticsearch/data目录并设置权限,否则会因为无权限访问而启动失败。

  1. # 创建目录

  2. mkdir /mydata/elasticsearch/data/

  3. # 创建并改变该目录权限

  4. chmod 777 /mydata/elasticsearch/data

nginx

需要拷贝nginx配置文件,否则挂载时会因为没有配置文件而启动失败。

  1. # 创建目录之后将nginx.conf文件上传到该目录下面

  2. mkdir /mydata/nginx/

执行docker-compose-env.yml脚本

将该文件上传的linux服务器上,执行docker-compose up命令即可启动mall所依赖的所有服务。

version: '3'
services:
  mysql:
    image: mysql:5.7
    container_name: mysql
    command: mysqld --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: root #设置root帐号密码
    ports:
      - 3306:3306
    volumes:
      - /mydata/mysql/data/db:/var/lib/mysql #数据文件挂载
      - /mydata/mysql/data/conf:/etc/mysql/conf.d #配置文件挂载
      - /mydata/mysql/log:/var/log/mysql #日志文件挂载
  redis:
    image: redis:3.2
    container_name: redis
    command: redis-server --appendonly yes
    volumes:
      - /mydata/redis/data:/data #数据文件挂载
    ports:
      - 6379:6379
  nginx:
    image: nginx:1.10
    container_name: nginx
    volumes:
      - /mydata/nginx/nginx.conf:/etc/nginx #配置文件挂载
      - /mydata/nginx/html:/usr/share/nginx/html #静态资源根目录挂载
      - /mydata/nginx/log:/var/log/nginx #日志文件挂载
    ports:
      - 80:80
  rabbitmq:
    image: rabbitmq:3.7.15-management
    container_name: rabbitmq
    volumes:
      - /mydata/rabbitmq/data:/var/lib/rabbitmq #数据文件挂载
      - /mydata/rabbitmq/log:/var/log/rabbitmq #日志文件挂载
    ports:
      - 5672:5672
      - 15672:15672
  elasticsearch:
    image: elasticsearch:5.6.13 #6.4.0无法启动,用5.6.13就可以
    container_name: elasticsearch
    environment:
      - "cluster.name=elasticsearch" #设置集群名称为elasticsearch
      - "discovery.type=single-node" #以单一节点模式启动
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m" #设置使用jvm内存大小
    volumes:
      - /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins #插件文件挂载
      - /mydata/elasticsearch/data:/usr/share/elasticsearch/data #数据文件挂载
    ports:
      - 9200:9200
  kibana:
    image: kibana:6.4.0
    container_name: kibana
    links:
      - elasticsearch:es #可以用es这个域名访问elasticsearch服务
    depends_on:
      - elasticsearch #kibana在elasticsearch启动之后再启动
    environment:
      - "elasticsearch.hosts=http://es:9200" #设置访问elasticsearch的地址
    ports:
      - 5601:5601
  mongo:
    image: mongo:3.2
    container_name: mongo
    volumes:
      - /mydata/mongo/db:/data/db #数据文件挂载
    ports:
      - 27017:27017

上传完后在当前目录下执行如下命令:

  1. docker-compose -f docker-compose-env.yml up -d

elasticsearch
需要安装中文分词器IKAnalyzer,并重新启动。
docker exec -it elasticsearch /bin/bash
#此命令需要在容器中运行
elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.4.0/elasticsearch-analysis-ik-6.4.0.zip
docker restart elasticsearch

mysql-(不要去掉更改下面的utf8编码,否则读取数据库到前端会乱码)
需要创建mall数据库并创建一个可以远程访问的对象reader。
将mall.sql文件拷贝到mysql容器的/目录下:
docker cp /mydata/mall.sql mysql:/
进入mysql容器并执行如下操作:
#进入mysql容器
docker exec -it mysql /bin/bash
#连接到mysql服务
mysql -uroot -proot --default-character-set=utf8
#创建远程访问用户
grant all privileges on *.* to 'reader' @'%' identified by '123456';
#创建mall数据库
create database mall character set utf8;
#使用mall数据库
use mall;
#导入mall.sql脚本
source /mall.sql;

RabbitMQ配置
进入容器并开启管理功能:
docker exec -it rabbitmq /bin/bash
rabbitmq-plugins enable rabbitmq_management

开启防火墙端口
  1. firewall-cmd --zone=public --add-port=8080/tcp --permanent
  2. firewall-cmd --zone=public --add-port=8081/tcp --permanent
  3. firewall-cmd --zone=public --add-port=8085/tcp --permanent
  4. firewall-cmd --zone=public --add-port=15672/tcp --permanent
  5. firewall-cmd --zone=public --add-port=9200/tcp --permanent
  6. firewall-cmd --zone=public --add-port=5601/tcp --permanent
  7. firewall-cmd --reload

嫌麻烦直接关掉防火墙也行

systemctl stop firewalld

运行admin、portal、search三个模块。

version: '3'
services:
  mall-admin:
    image: mall/mall-admin:1.0-SNAPSHOT
    container_name: mall-admin
    ports:
      - 8080:8080
    external_links:
      - mysql:db #可以用db这个域名访问mysql服务
  mall-search:
    image: mall/mall-search:1.0-SNAPSHOT
    container_name: mall-search
    ports:
      - 8081:8081
    external_links:
      - elasticsearch:es #可以用es这个域名访问elasticsearch服务
      - mysql:db #可以用db这个域名访问mysql服务
  mall-portal:
    image: mall/mall-portal:1.0-SNAPSHOT
    container_name: mall-portal
    ports:
      - 8085:8085
    external_links:
      - redis:redis #可以用redis这个域名访问redis服务
      - mongo:mongo #可以用mongo这个域名访问mongo服务
      - mysql:db #可以用db这个域名访问mysql服务
      - rabbitmq:rabbit #可以用rabbit这个域名访问rabbitmq服务
docker-compose -f docker-compose-app.yml up -d

整个服务就运行起来了。

更改阿里云的安全组添加8080、8081、8085端口,前端就可以访问了。

http://ip:8080/swagger-ui.html 

http://ip:8081/swagger-ui.html 

http://ip:8085/swagger-ui.html 

猜你喜欢

转载自www.cnblogs.com/HugoLester/p/11165633.html