docker部署springboot專案到伺服器

2023-06-15 15:00:50

docker部署springboot demo到vps

docker安裝

首先檢查docker是否安裝
docker version

出現上述介面就是安裝成功

如果沒有安裝docker的話,執行以下命令
刪除舊版本的docker

yum remove docker \
    docker-client \
    docker-client-latest \
    docker-common \
    docker-latest \
    docker-latest-logrotate \
    docker-logrotate \
    docker-selinux \
    docker-engine-selinux \
    docker-engine

安裝依賴包(centos)

yum install -y yum-utils \
    device-mapper-persistent-data \
    lvm2

安裝docker
yum install docker
啟動docker

systemctl enable docker
systemctl start docker

檢視安裝結果
docker version

設定映象(如果是阿里雲的伺服器,安裝後預設就是阿里雲的docker映象源,可以不用修改)

{
  "registry-mirrors": [
    "https://registry.docker-cn.com",
    "http://hub-mirror.c.163.com",
    "https://docker.mirrors.ustc.edu.cn"
  ]
}

重啟
systemctl restart docker

安裝portainer,視覺化介面

docker pull portainer/portainer

sudo docker volume create portainer_data

sudo 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-ce
出現以下介面說明安裝成功了

如果之前安裝過,忘記密碼,可以進行如下操作
停止正在執行的Portainer

docker stop "id-portainer-container"

執行重置命令

docker run --rm -v portainer_data:/data portainer/helper-reset-password

如果你的Portainer 掛載目錄不是 portainer_data 則會提示
Unable to locate /data/portainer.db on disk

檢視你的portainer 掛載資訊
docker inspect "id-portainer-container"

需要執行的重置命令為:

docker run --rm -v /var/snap/docker/common/var-lib-docker/volumes/c822de987380b92b5372fad6a19fd26bc6748fadf7ca2e404674cd7bfdcaa387/_data:/data portainer/helper-reset-password

如果成功,輸出應如下所示:


Password successfully updated for user: admin

Use the following password to login: &_4#\3^5V8vLTd)E"NWiJBs26G*9HPl1

重新執行portianer

docker start "id-portainer-container"

下面就是進入主頁面,可以進行更改密碼

安裝mysql

docker pull mysql

#MYSQL_ROOT_PASSWORD後面填寫自己的root密碼
docker run --name mysql80 -e MYSQL_ROOT_PASSWORD=123456-d mysql
#也可以執行如下命令,自動開啟MySQL容器在後臺執行
docker run -d --name mysql80 -e MYSQL_ROOT_PASSWORD=123456 --restart always mysql

阿里雲安全組放行3306埠

使用navicat連線伺服器的mysql
這時會出現錯誤

進入portainer介面mysql的console介面

mysql -uroot -p
此時連線成功

使用以下命令進行授權所有主機進行存取

# 修改授權,賦予任何主機存取資料庫的許可權
# mysql8.0以下
GRANT ALL PRIVILEGES ON *.* TO 「root」@」%」 IDENTIFIED BY '資料庫密碼' WITH GRANT OPTION;   
GRANT ALL PRIVILEGES ON *.* TO 「root」@」%」 IDENTIFIED BY '123456' WITH GRANT OPTION;   

mysql8.0以上
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';
FLUSH PRIVILEGES;

navicat連線成功

然後建立資料庫
將本地springboot專案打包成jar包
編寫dockerfile

FROM openjdk:8
# VOLUME 指定了臨時檔案目錄為/tmp。
# 其效果是在主機 /var/lib/docker 目錄下建立了一個臨時檔案,並連結到容器的/tmp
VOLUME /tmp 
# 將jar包新增到容器中並更名為app.jar
ADD user.jar app.jar 
# 執行jar包
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

建立docker資料夾,將jar包與Dockerfile移動到該資料夾,進入該資料夾,執行命令:
docker build -t app .
檢視映象
docker images
執行映象
docker run -d -p 8082:8888 app
存取地址,專案部署成功