MiniMall:Linux環境下的部署(基於Docker)(上)

本文將以圖文的形式說一下Mini-Mall項目是如何在Linux環境下基於Docker部署的,主要包括JDK、Docker、MySQL、Nginx、Redis、MongoDB、RabbitMQ、ELK(非必須)、Seata、Zipkin(非必須)等。

前提條件:請先準備好CentOS 7服務器環境,服務器內存最好在8G以上。

其它說明:

  • 遠程工具:SecureCRT
  • 文件傳輸工具:WinSCP

1. JDK

1.1 下載安裝包

1.2 解壓並配置變量

  • 解壓到/usr/local/jdk1.8
# 解壓
tar -zxvf jdk-8u171-linux-x64.tar.gz
# 移動到/usr/local/jdk1.8下
mv jdk1.8.0_171 /usr/local/jdk1.8/
  • 配置環境變量
# 編輯/etc/profile
vim /etc/profile
# 在profile文件末尾添加以下內容
export JAVA_HOME=/usr/local/jdk1.8/jdk1.8.0_171
export CLASSPATH=.:${JAVA_HOME}/jre/lib/rt.jar:${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar
export PATH=$PATH:${JAVA_HOME}/bin
# 生效環境變量
source /etc/profile

1.3 測試

使用java -version命令測試是否安裝成功。

在這裏插入圖片描述

2. Docker

官網地址:https://www.docker.com/,安裝過程如下:

# 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服務:systemctl start docker
  • 停止docker服務:systemctl stop docker
  • 設置開機啓動docker服務:systemctl enable docker

更多Docker詳情內容,可參考《學習Docker,這裏沒有廢話》這篇文章。

3. MySQL

  1. 拉取mysql鏡像

    docker pull mysql:5.6
    
  2. 創建並啓動容器

    docker run -id \
    -p 3306:3306 \
    --name=mysql \
    -v /usr/local/docker/mysql/conf:/etc/mysql/conf.d \
    -v /usr/local/docker/mysql/logs:/logs \
    -v /usr/local/docker/mysql/data:/var/lib/mysql \
    -e MYSQL_ROOT_PASSWORD=Anbang713 \
    mysql:5.6
    
  3. 進入到mysql容器

    docker exec -it mysql /bin/bash
    
  4. 登錄mysql,設置root可以通過任何客戶端連接

    # 1.登錄mysql
    mysql -u root -p
    # 2.設置root用戶可以遠程訪問
    GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "Anbang713";
    # 3.刷新權限
    flush privileges;
    
  5. 客戶端連接測試

在這裏插入圖片描述

  1. 創建數據庫和表

將項目工程中的mall-doc下對應各個微服務的數據庫執行腳本導入即可。

在這裏插入圖片描述

4. Nginx

  1. 拉取nginx鏡像

    docker pull nginx
    
  2. 編寫nginx.conf

    # 創建nginx.conf,添加以下內容
    vim /var/local/docker/nginx/conf/nginx.conf
    
    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;
        keepalive_timeout  65;
    
        include /etc/nginx/conf.d/*.conf;
    	
    	server {
    		listen       80;
    		server_name  api.mall.com;
    
    		proxy_set_header X-Forwarded-Host $host;
    		proxy_set_header X-Forwarded-Server $host;
    		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    		proxy_set_header Host $host; # 轉發時,攜帶自身的host,而不是轉發後的host:127.0.0.1
    
    		location / {
    			proxy_pass http://192.168.1.17:9015; #將請求轉發到網關
    			proxy_connect_timeout 600;
    			proxy_read_timeout 600;
    		}
    	}
    	
    	server {
    		listen       80;
    		server_name  manage.mall.com;
    
    		add_header Access-Control-Allow-Origin *;
    		add_header Access-Control-Allow-Headers X-Requested-With;
    		add_header Access-Control-Allow-Methods GET,POST,OPTIONS;
    
    		location / {
    			root /usr/share/nginx/html/mini-mall-web; #這裏配的是docker裏nginx的文件路徑而不是虛擬機的文件路徑
    			autoindex on;
    		}
    	}
    
    }
    
  3. 創建並啓動容器

    docker run -id \
    --name=nginx \
    -p 80:80 \
    -v /usr/local/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
    -v /usr/local/docker/nginx/logs:/var/log/nginx \
    -v /usr/local/docker/nginx/html:/usr/share/nginx/html \
    nginx
    
  4. 瀏覽器訪問nginx

在這裏插入圖片描述

注意:別忘記在/etc/hosts文件裏添加api.mall.commanage.mall.com的映射。

5. Redis

  1. 拉取redis鏡像

    docker pull redis:5.0
    
  2. 創建並啓動容器

    docker run -id --name=redis -p 6379:6379 redis:5.0
    
  3. 客戶端連接測試

在這裏插入圖片描述

6. MongoDB

  1. 拉取鏡像

    docker pull mongo
    
  2. 創建並啓動容器

    docker run -id \
    --name=mongodb \
    -p 27017:27017 \
    -v /usr/local/docker/mongodb/db:/data/db \
    mongo
    

7. RabbitMQ

  1. 拉取鏡像

    # 帶控制檯
    docker pull rabbitmq:management
    
  2. 創建並啓動容器

    docker run -id --name rabbitmq -e RABBITMQ_DEFAULT_USER=root -e RABBITMQ_DEFAULT_PASS=Anbang713 -p 15672:15672 -p 5672:5672 rabbitmq:management
    
  3. 瀏覽器訪問控制檯測試

在這裏插入圖片描述

8. Seata

  1. 拉取鏡像

    docker pull seataio/seata-server
    
  2. 創建並啓動容器

    docker run -id \
    --name seata-server \
    -p 8091:8091 \
    -e SEATA_CONFIG_NAME=file:/root/seata-config/registry \
    -v /usr/local/docker/seata/conf/:/root/seata-config \
    -v /usr/local/docker/seata/logs/:/root/logs \
    seataio/seata-server
    
  3. 配置文件

    • register.conf
    registry {
      # file 、nacos 、eureka、redis、zk、consul、etcd3、sofa
      type = "eureka"
    
      nacos {
        serverAddr = "localhost"
        namespace = ""
        cluster = "default"
      }
      eureka {
        serviceUrl = "http://Anbang713:pwd713@localhost:9010/eureka"
        application = "default"
        weight = "1"
      }
      redis {
        serverAddr = "localhost:6379"
        db = "0"
      }
      zk {
        cluster = "default"
        serverAddr = "127.0.0.1:2181"
        session.timeout = 6000
        connect.timeout = 2000
      }
      consul {
        cluster = "default"
        serverAddr = "127.0.0.1:8500"
      }
      etcd3 {
        cluster = "default"
        serverAddr = "http://localhost:2379"
      }
      sofa {
        serverAddr = "127.0.0.1:9603"
        application = "default"
        region = "DEFAULT_ZONE"
        datacenter = "DefaultDataCenter"
        cluster = "default"
        group = "SEATA_GROUP"
        addressWaitTime = "3000"
      }
      file {
        name = "file.conf"
      }
    }
    
    config {
      # file、nacos 、apollo、zk、consul、etcd3
      type = "file"
    
      nacos {
        serverAddr = "localhost"
        namespace = ""
        group = "SEATA_GROUP"
      }
      consul {
        serverAddr = "127.0.0.1:8500"
      }
      apollo {
        app.id = "seata-server"
        apollo.meta = "http://192.168.1.204:8801"
        namespace = "application"
      }
      zk {
        serverAddr = "127.0.0.1:2181"
        session.timeout = 6000
        connect.timeout = 2000
      }
      etcd3 {
        serverAddr = "http://localhost:2379"
      }
      file {
        name = "file.conf"
      }
    }
    
    • file.conf
    
    ## transaction log store, only used in seata-server
    store {
      ## store mode: file、db
      mode = "db"
    
      ## file store property
      file {
        ## store location dir
        dir = "sessionStore"
        # branch session size , if exceeded first try compress lockkey, still exceeded throws exceptions
        maxBranchSessionSize = 16384
        # globe session size , if exceeded throws exceptions
        maxGlobalSessionSize = 512
        # file buffer size , if exceeded allocate new buffer
        fileWriteBufferCacheSize = 16384
        # when recover batch read size
        sessionReloadReadSize = 100
        # async, sync
        flushDiskMode = async
      }
    
      ## database store property
      db {
        ## the implement of javax.sql.DataSource, such as DruidDataSource(druid)/BasicDataSource(dbcp) etc.
        datasource = "dbcp"
        ## mysql/oracle/h2/oceanbase etc.
        dbType = "mysql"
        driverClassName = "com.mysql.jdbc.Driver"
        url = "jdbc:mysql://127.0.0.1:3306/seata"
        user = "root"
        password = "Anbang713"
        minConn = 1
        maxConn = 10
        globalTable = "global_table"
        branchTable = "branch_table"
        lockTable = "lock_table"
        queryLimit = 100
      }
    }
    
  4. 測試

因爲我們是使用Eureka作爲Seata的註冊配置中心,所以我們需要先啓動Eureka,這裏就先暫不測試。

9. Zipkin

  1. 拉取zipkin鏡像

    docker pull openzipkin/zipkin
    
  2. 創建並啓動容器

    docker run -id \
    --name zipkin \
    -p 9411:9411 \
    -e STORAGE_TYPE=mysql \
    -e MYSQL_DB=mall_zipkin \
    -e MYSQL_USER=root \
    -e MYSQL_PASS=Anbang713 \
    -e MYSQL_HOST=192.168.1.17 \
    -e MYSQL_TCP_PORT=3306 \
    -e RABBIT_ADDRESSES=192.168.1.17:5672 \
    -e RABBIT_USER=root \
    -e RABBIT_PASSWORD=Anbang713 \
    -e RABBIT_QUEUE=zipkin \
    openzipkin/zipkin
    
  3. 測試

需要注意的是,啓動Zipkin之前,我們要先啓動mysql容器和RabbitMQ容器,而判斷Zipkin是否啓動成功很簡單,打開RabbitMQ界面控制檯,如果有自動創建zipkin隊列,則說明啓動成功。

在這裏插入圖片描述

10. Elastic Stack

注意:該技術棧的版本要統一,本次安裝7.6.0(當前最新版本7.6.2)

10.1 ElasticSearch

官方安裝說明文檔:https://www.elastic.co/guide/en/elasticsearch/reference/current/docker.html

  1. 拉取鏡像

    docker pull elasticsearch:7.6.0
    
  2. 創建並啓動容器

    docker run -id \
    --name elasticsearch \
    -p 9200:9200 \
    -p 9300:9300 \
    -e "discovery.type=single-node" \
    elasticsearch:7.6.0
    
  3. 測試

    curl 127.0.0.1:9200
    

在這裏插入圖片描述

10.2 Kibana

官方安裝說明文檔:https://www.elastic.co/guide/en/kibana/current/docker.html

  1. 拉取鏡像

    docker pull kibana:7.6.0
    
  2. 創建並啓動容器

    docker run -id \
    --name kibana \
    -p 5601:5601 \
    -v /usr/local/docker/elk/kibana/kibana.yml:/usr/share/kibana/config/kibana.yml \
    kibana:7.6.0
    
  3. kibana.yml配置

    server.name: kibana
    server.host: "0.0.0.0"
    elasticsearch.hosts: [ "http://192.168.1.17:9200" ]
    i18n.locale: "zh-CN"
    
  4. 瀏覽器訪問測試

在這裏插入圖片描述

10.3 filebeat

官方安裝說明文檔:https://www.elastic.co/guide/en/beats/filebeat/current/running-on-docker.html

  1. 拉取鏡像

    docker pull store/elastic/filebeat:7.6.0
    
  2. 創建並啓動容器

    docker run -id \
    --name filebeat \
    -p 5044:5044 \
    --volume="/usr/local/docker/elk/filebeat/mini-mall.yml:/usr/share/filebeat/filebeat.yml:ro" \
    --volume="/var/lib/docker/containers:/var/lib/docker/containers:ro" \
    --volume="/var/run/docker.sock:/var/run/docker.sock:ro" \
    store/elastic/filebeat:7.6.0
    
  3. filebeat.yml配置

    filebeat.inputs:
    - type: log
      enabled: true
      paths:
    	- /usr/local/mini-mall/logs/*/*.log
    	- /var/lib/docker/containers/*/*-json.log
    setup.kibana:
      host: 192.168.1.17:5601
    output.elasticsearch:
      hosts: ["192.168.1.17:9200"]
    

至此,所需的環境已全部搭建完成,後面我們需要將製作微服務鏡像,讓它們在Linux環境跑起來。下回見嘍。

——End——
更多精彩分享,可掃碼關注微信公衆號哦。

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章