Linux版本的項目環境搭建

来源:https://www.cnblogs.com/gongss/archive/2022/06/05/16345015.html
-Advertisement-
Play Games

項目環境docker及docker-compose文檔 1、Linux環境介紹 centos7.6 16G以上記憶體空間(至少8G) 2、靜態IP設置 1、找到配置文件 cd /etc/sysconfig/network-scripts/ vi ifcfg-ens33 TYPE=EthernetPRO ...


項目環境docker及docker-compose文檔

1、Linux環境介紹

  • centos7.6

  • 16G以上記憶體空間(至少8G)

 

2、靜態IP設置

1、找到配置文件
cd /etc/sysconfig/network-scripts/
vi ifcfg-ens33
----------------------------
TYPE=Ethernet
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=static
DEFROUTE=yes
IPADDR=192.168.200.188
NETMASK=255.255.255.0
GATEWAY=192.168.200.2
DNS1=114.114.114.114
DNS2=8.8.8.8
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy
NAME=ens33
UUID=b8fd5718-51f5-48f8-979b-b9f1f7a5ebf2
DEVICE=ens33
ONBOOT=yes
-----------------------------------

重啟網卡
service network restart

測試網卡
ping www.baidu.com 如果有位元組輸出,則表示網路正常

3、JDK安裝

# jdk鏡像倉庫:https://repo.huaweicloud.com/java/jdk/8u171-b11/

#下載wget命令
yum install wget

# 下載、解壓jdk
wget https://repo.huaweicloud.com/java/jdk/8u171-b11/jdk-8u171-linux-x64.tar.gz
#解壓
tar -zxf jdk-8u171-linux-x64.tar.gz
#移動文件夾中
mv jdk1.8.0_171 /usr/local

# 配置環境
vi /etc/profile

# 添加內容:
export JAVA_HOME=/usr/local/jdk1.8.0_171
export PATH=$JAVA_HOME/bin:$PATH

# 配置生效命令
source /etc/profile
#查看j版本命令
java -version

 

4、Docker安裝

安裝docker

# 1、yum 包更新到最新,需要幾分鐘時間
sudo yum update
# 2、作用:安裝需要的軟體包, yum-util 提供yum-config-manager功能,另外兩個是devicemapper驅動依賴的
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
# 3、 設置yum源
# 3.1、方案一:使用ustc的(預設的)
sudo yum-config-manager --add-repo http://mirrors.ustc.edu.cn/docker-ce/linux/centos/docker-ce.repo
# 3.2、方案二:使用阿裡雲(推薦)
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 4、 安裝docker;出現輸入的界面都按 y
sudo yum install -y docker-ce
# 5、 查看docker版本
docker -v

#開機自啟動
systemctl enable docker

設置鏡像加速器

# 執行如下命令:
mkdir /etc/docker 表示創建一個文件夾
#如果有該文件則進入編輯狀態,如果沒有,則創建該文件然後進入編輯狀態
vi /etc/docker/daemon.json  
#編寫以下內容
{
 "registry-mirrors": ["https://7oc12mqc.mirror.aliyuncs.com"]
}

註意:[“自己的鏡像加速器地址”]

5、Docker-compose安裝

#國內資源(建議)
curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.4/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

# 設置文件可執行許可權
chmod +x /usr/local/bin/docker-compose
# 查看版本信息
docker-compose -version

6、Nacos安裝

  • 創建一個文件夾

mkdir nacos
  • 進入該文件夾中

cd nacos

vi docker-compose.yml
  • 編寫docker-compose.yml文件

version: "2"
services:
nacos:
  image: nacos/nacos-server:1.4.1
  container_name: nacos
  environment:
  - MODE=standalone
  volumes:
  - /root/nacos/logs:/home/nacos/logs
  -  /root/nacos/init.d/custom.properties:/home/nacos/init.d/custom.properties
  ports:
  - "8848:8848"
  restart: always
  • 創建文件夾及文件

cd nacos

mkdir init.d

cd init.d

touch custom.properties
  • 執行腳本

docker-compose up -d

 

7、MySQL安裝

創建docker-compose.yml

  • 創建一個文件夾

mkdir mysql
  • 進入mysql文件夾中創建一個docker-compose.yml文件

cd mysql

vi docker-compose.yml
  • 在docker-compose.yml中加入以下內容

version: '3'
services:
  mysql:
    container_name: mysql
    environment:
      TZ: Asia/Shanghai
      MYSQL_ROOT_PASSWORD: "root"
    image: "mysql:5.7"
    restart: always
    volumes:
      - "./conf/my.cnf:/etc/my.cnf"
      - "./data:/var/lib/mysql"
    ports:
      - "3306:3306"
  • 創建文件(在mysql文件夾下)

mkdir conf
cd conf
touch my.cnf
  • 在mysql文件夾下執行腳本

docker-compose up -d

8、ElasticSearch安裝

  • 創建一個文件夾

mkdir es
  • 進入es文件夾中創建一個docker-compose.yml文件

vi docker-compose.yml
  • 在docker-compose.yml中加入以下內容

version: '3'
services:
  elasticsearch:
    image: elasticsearch:7.4.0
    container_name: elasticsearch
    restart: always
    environment:
      - bootstrap.memory_lock=true
      - http.cors.enabled=true
      - http.cors.allow-origin=*
      - "discovery.type=single-node"
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
    ulimits:
      memlock:
        soft: -1
        hard: -1
    volumes:
      - /root/es/plugins:/usr/share/elasticsearch/plugins
    ports:
      - 9200:9200
      - 9300:9300
  kibana:
    image: kibana:7.4.0
    container_name: kibana
    environment:
      - SERVER_NAME=kibana
      - ELASTICSEARCH_URL=http://192.168.200.137:9200
      - XPACK_MONITORING_ENABLED=true
    ports:
      - 5601:5601
    depends_on:
      - elasticsearch
    external_links:
      - elasticsearch
  • es文件夾下執行腳本

docker-compose up -d
  • 設置中文IK分詞器

因為在創建elasticsearch容器的時候,映射了目錄,所以可以在宿主機上進行配置ik中文分詞器

在去選擇ik分詞器的時候,需要與elasticsearch的版本好對應上

把資料中的ik-7.4.0.tar上傳到伺服器上,放到對應目錄(plugins)解壓

#上傳壓縮包到Linux中

#切換目錄
cd es/plugins
#新建目錄
mkdir analysis-ik

#root根目錄解壓
tar -xf ik-7.4.0.tar -C /root/es/plugins/analysis-ik
  • 在重新啟動es,進行測試

docker restart elasticsearch
  • 連接kibana,測試iK分詞器

# ik_max_word中文分詞器
GET _analyze
{
  "analyzer": "ik_max_word",
  "text":"中國人民真好看"
}

# ik_smart中文分詞器
GET _analyze
{
  "analyzer": "ik_smart",
  "text":"中國人民真好看"
}

# 預設分詞器
GET _analyze
{
  "analyzer": "standard",
  "text":"中國人民真好看"
}

9、MinIo安裝

  • 創建文件夾

mkdir minio
  • 進入文件夾

cd minio
  • 創建docker-compose.yml

vi docker-compose.yml
  • 編寫以下內容

version: '3'
services:
  minio:
    image: minio/minio:RELEASE.2021-04-18T19-26-29Z
    container_name: myminio
    ports:
      - 9000:9000
    volumes:
      - /var/minio/data:/data
      - /var/minio/config:/root/.minio
    environment:
      MINIO_ACCESS_KEY: "minio"
      MINIO_SECRET_KEY: "minio123"
    command: server /data
    restart: always
  • 執行命令

docker-compose up -d

10、Redis安裝

  • 創建一個文件夾

mkdir redis
  • 進入redis文件夾中創建一個docker-compose.yml文件

cd redis

vi docker-compose.yml
  • 在docker-compose.yml中加入以下內容

version: '3'
services:
 redis:
  container_name: redis
  image: redis:5.0.7
  restart: always
  ports:
    - 6379:6379
  volumes:
    - ./conf/redis.conf:/etc/redis/redis.conf:rw
    - ./data:/data:rw
  command:
    redis-server /etc/redis/redis.conf --appendonly yes
  environment:
    - TZ=Asia/Shanghai
  • redis文件夾下執行腳本

docker-compose up -d

11、Kafka安裝

  • 創建一個文件夾

mkdir kafka
  • 進入kafka文件夾中創建一個docker-compose.yml文件

cd kafka

vi docker-compose.yml
  • 在docker-compose.yml中加入以下內容

version: '3'
services:
  zookeeper-kafka:
    image: wurstmeister/zookeeper
    restart: unless-stopped
    hostname: zookeeper-kafka
    container_name: zookeeper-kafka
    ports:
      - 2777:2181
    volumes:
      - ./data:/data
      - ./datalog:/datalog
  kafka:
    image: wurstmeister/kafka:2.12-2.4.1
    depends_on: 
      - zookeeper-kafka
    container_name: kafka
    ports:
      - 9092:9092
    environment:
      KAFKA_ADVERTISED_HOST_NAME: kafka
      KAFKA_BROKER_ID: 0
      KAFKA_ZOOKEEPER_CONNECT: 192.168.200.135:2777
      KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://192.168.200.135:9092
      KAFKA_LISTENERS: PLAINTEXT://0.0.0.0:9092
    restart: unless-stopped
    volumes:
      - ./docker.sock:/var/run/docker.sock

KAFKA_ZOOKEEPER_CONNET:IP:zookeeper的埠號

IP要改成自己伺服器的ip地址

  • 在kafka文件夾下執行以下命令

docker-compose up -d

12、Kafka-manager安裝(選裝)

#拉取鏡像
docker pull sheepkiller/kafka-manager
#創建容器
docker run -di --name=kafka-manager  -p 9001:9000 --restart=always -e ZK_HOSTS=192.168.200.137:2777 sheepkiller/kafka-manager

ZK_HOSTS=192.168.200.129:2777

表示關聯zookeeper的地址及埠號, 2777是zookeeper的對外埠號

13、MongoDB安裝

  • 創建一個文件夾

mkdir mongo
  • 進入mongo文件夾中創建一個docker-compose.yml文件

cd mongo

vi docker-compose.yml
  • 在docker-compose.yml中加入以下內容

version: '3.1'
services:
  mongo:
    image: mongo:5.0.2
    restart: always
    container_name: mongo  
    hostname: mongo
    environment:
      #用戶名密碼
      MONGO_INITDB_ROOT_USERNAME: root
      MONGO_INITDB_ROOT_PASSWORD: root
    ports:
      - 27017:27017
    volumes: 
      - ./data:/data/db
    networks:
          mongo:
            aliases:
            - mongo1  
networks:
  mongo:
    driver: bridge
  • mongo文件夾下執行腳本

docker-compose up -d

安裝完後,要對mongo進行認證操作cls

進入mongo內部
[root@localhost ~]# docker exec -it mongo /bin/bash
root@mongo:/# mongo
MongoDB shell version v4.4.5
connecting to: mongodb://127.0.0.1:27017/?compressors=disabled&gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("f7c7c594-d5dd-473a-9ded-43609ac16a28") }
MongoDB server version: 4.4.5
> use admin
switched to db admin
> db.auth("root","root")
1
> show dbs
admin             0.000GB
config            0.000GB
local             0.000GB

14、Xxl-job安裝

  • 創建一個文件夾

mkdir xxljob
  • 進入xxljob文件夾中創建一個docker-compose.yml文件

cd xxljob

vi docker-compose.yml
  • 在docker-compose.yml中加入以下內容

version: '3'
services:
  xxl-job:
    image: xuxueli/xxl-job-admin:2.3.0
    container_name: xxl-job
    environment:
      PARAMS: "--spring.datasource.url=jdbc:mysql://192.168.200.137:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai  --spring.datasource.username=root  --spring.datasource.password=root"
    ports:
      - 8888:8080
    volumes:
      - /data/docker/xxl-job/logs/:/data/applogs/xxl-job/
  • xxljob文件夾下執行腳本

    docker-compose up -d

15、seata安裝

1、安裝

創建文件夾

mkdir seata

進入文件夾,然後創建docker-compose.yml

cd seata
vi docker-compose.yml

寫入以下內容

version: "3"
services:
  seata-server:
    image: seataio/seata-server:1.4.2
    hostname: seata-server
    container_name: seata
    restart: always
    ports:
      - "8091:8091"
    environment:
      - SEATA_PORT=8091
      - SEATA_IP=192.168.200.104
    volumes:
      - /root/seata/config:/root/seata-config

生成容器

docker-compose up -d		

查看容器是否啟動

docker ps 

 

2、修改參數

1、進入容器內部

docker exec -it seata sh

 

2、進入resources文件夾下

cd resources

 

3、修改registry.conf配置

vi registry.conf

註冊中心配置:

 

配置中心:

 

具體詳情:(也可參考windwos環境中的registry.conf文件)

registry {
  # file ...nacos ...eureka...redis...zk...consul...etcd3...sofa
  type = "nacos"

  nacos {
    application = "seata-tc-server"
    serverAddr = "192.168.200.104:8848"
    group = "SEATA_GROUP"
    namespace = ""
    cluster = "SH"
    username = "nacos"
    password = "nacos"
  }
}
config {                                       
  # file...nacos ...apollo...zk...consul...etcd3
  type = "nacos"                                
                                                
  nacos {                                      
    serverAddr = "192.168.200.104:8848"         
    namespace = ""                              
    group = "SEATA_GROUP"                       
    username = "nacos"                          
    password = "nacos"                          
    dataId = "seataServer.properties"          
  }            
}

3、退出容器

exit

4、重啟容器

docker restart seata

5、查看日誌

docker logs -f seata

 

 

docker cp mysql:/etc/mysql/mysql.conf.d/mysqld.cnf  /root/mysqld.cnf


wait_timeout=86400

docker cp mysqld.cnf  mysql:/etc/mysql/mysql.conf.d/mysqld.cnf
 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、FastDFS 1.1、瞭解基礎概念 1.1.1、什麼是分散式文件系統? 全稱:Distributed File System,即簡稱的DFS 這個東西可以是一個軟體,也可以說是伺服器,和tomcat差不多,即相當於軟體也相當於是伺服器,這個軟體就是用來管理文件的 這個軟體所管理的文件通常不是在 ...
  • React兄弟組件之間的通信 Child2組件需要去更改Child1組件中的數據。 因為Child1和Child2是兄弟組件 所以數據和事件都放在最進的父級組件中去 兄弟組件通信的簡單使用 import React from 'react'; //這個是react這個包,我們是需要的 import ...
  • 組件中的props 在react中,props的特點是: 1.可以給組件傳遞任意類型的數據 2.props是只讀的對象,只能夠讀取屬性的值,無法修改對象 如過我們強行修改數據,會報錯,告訴我們該屬性是只讀屬性。 ps:在類組件中,如果寫了構造函數,應該將props傳遞給super(). 否則無法在構 ...
  • 本文目錄: 字體標簽 我是字體標簽 <font> 我是字體標簽 </font> 效果: 我是紅色 <font color="red"> 我是紅色 </font> 效果: 我是楷體 <font face="楷體"> 我是楷體 </font> 效果: 我是4號字體 <font size="4"> 我是4 ...
  • 兩個特性說明Dapr是比SpringCloud和Istio更有前途的微服務開發框架。 ...
  • 從本篇文章開始,筆者打算寫一個系列的《clickhouse專欄》,其全稱是Click Stream,Data WareHouse,簡稱ClickHouse。從其全稱中的“Data WareHouse”,我們可以看出clickhouse的定位是數據倉庫。那麼“數據倉庫”和“資料庫”有什麼區別呢?理解這 ...
  • 1 與其它協程庫使用對比 這個 C 協程庫是雲風(cloudwu) 寫的,其介面風格與 Lua 協程類似,並且都是非對稱 stackful 協程。這個是源代碼中的示例: #include "coroutine.h" #include <stdio.h> struct args { int n; }; ...
  • #結構 ##順序結構 JAVA的基本結構就是順序結構,除非特意指明,否則就按照順序,一句一句執行。 順序結構是最簡單的演算法結構 語句與語句之間,框與框之間按照從上到下的順序執行,它是任何演算法都離不開的基本演算法結構 ##選擇結構 if單選擇結構 if雙選擇結構 if多選擇結構 嵌套的if結構 swit ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...