整个Springboot项目都容器化,部署到云服务器。
创建并运行一个MySQL容器:
docker run --name=mysql-test -itd -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root123456 -d mysql
参数说明:
–name:指定了容器的名称,方便之后进入容器的命令行。
-itd:其中,i是交互式操作,t是一个终端,d指的是在后台运行。
-p:指在本地生成一个随机端口,用来映射mysql的3306端口。
-e:设置环境变量。
MYSQL_ROOT_PASSWORD=root123456:指定了MySQL的root密码
-d mysql:指运行mysql镜像,设置容器在在后台一直运行。
docker build -t image_name . # 根据当前目录下的Dockerfile建立image
docker rmi xxx # 删除image
docker rm xxx # 删除container
docker log -f xxx # 监听container日志
docker ps -a # 显示所有container
docker exec -it container command
mysql -u root -p # 登录
CREATE USER 'new_username'@'%' IDENTIFIED BY 'user_password'; # 创建新用户
GRANT ALL PRIVILEGES ON database_name.* TO 'new_username'@'localhost'; # 授予权限
FLUSH PRIVILEGES; # 刷新权限
use mysql # 使用mysql数据库
服务器的3306没有监听。Docker容器运行有问题。Port需要显示如下,说明端口是在监听的。
可以用这个命令看。
netstat -lnp | grep 3306
在运行容器时,加上-p xxx:xxx,指定端口映射。
注意的地方:
FROM ubuntu:20.04
# 把当前目录下所有的文件复制。COPY会自动取出src内的内容,所以用../
# COPY SRC.. DEST
COPY ../ /app/fwc/
# 设置阿里云的 OpenJDK 镜像源并安装 OpenJDK
RUN echo "deb http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse" > /etc/apt/sources.list && \
echo "deb-src http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse" >> /etc/apt/sources.list && \
apt-get update && apt-get install -y \
# 下载需要的环境
openjdk-11-jdk \
python3 \
python3-pip \
# 清理缓存,减小image大小
&& apt-get clean && rm -rf /var/lib/apt/lists/*
# 创建 python 到 python3 的软链接。防止python报错找不到
RUN ln -s /usr/bin/python3 /usr/bin/python
WORKDIR /app/fwc/
# Add pip mirror
RUN python3 -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple --upgrade pip
RUN pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple
# Pip install
# 按照requirements下载包
RUN pip install --no-cache-dir --upgrade -r requirements.txt
# 设置环境变量
ENV JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64
# 设置工作目录(可选)
WORKDIR /app/fwc/frontend
# 在这里可以添加其他自定义步骤或命令
EXPOSE 8080
# 执行 Spring Boot 应用程序
ENTRYPOINT ["java", "-jar", "app.jar"]
用户可能是只允许本地登录。
用 select user, host from mysql 查看。如果用户的host是localhost,那么按照Mysql常用命令的顺序修改即可。
mysql -u root -p # 登录
update user set host = '%' where user = 'xxx';
GRANT ALL PRIVILEGES ON database_name.* TO 'new_username'@'%'; # 授予权限
FLUSH PRIVILEGES; # 刷新权限
在本地测试好环境,正确无误后!!!。编写Dockerfile,放在项目根目录;编写deploy.sh,也可以放在根目录,它用来自动化部署。
以下是个简单例子。
#! /bin/bash
# deploy
docker build -t web .
docker run -itd --name web -p 8080:8080 web
# docker start mysql # 如果数据库也部署在该机器,则需要开启~
# 类似的,开启其他依赖的服务
echo "Completed"
还有其他需求时,就再写。
不知道为什么,自己建一个文件补上。这边有解释
# Specifies the version of the Maven Wrapper.
wrapperVersion=1.0
# The URL to download Maven from.
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.3/apache-maven-3.6.3-bin.zip
# The URL of the Maven Wrapper jar.
wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar
# A list of system properties to be set.
systemProperties=example.property=value
然后就能用maven了。