前言
该技术博客是针对于B站教程的笔记总结,部署的项目源码去视频下方寻找下载,原作者为MarkerHup,链接如下: https://www.bilibili.com/video/BV1dk4y1r7pi?from=search&seid=14843346661632474214&spm_id_from=333.337.0.0
1、安装 Docker
首先打开linux环境,输入以下命令进行安装:
安装
yum install docker
检查是否安装成功
docker --version
#启动
systemctl start docker
如果下载很慢,可以切换到国内的阿里云镜像,进行下载:
换镜像源
sudo vim /etc/docker/daemon.json
内容如下:
{
"registry-mirrors": ["https://m9r2r2uj.mirror.aliyuncs.com"]
}
保存退出,重启docker:
systemctl restart docker
2、安装 Redis
首先在DockerHub搜索redis,点击进入详情页之后,拉到下面就可以看到how to use,如果需要选择特定的版本,有Supported tags给我们选择,然后如果拉取最新的版本的话,拉到下面就命令教程如下:
拉取redis的镜像
docker pull redis
查看本地redis镜像
docker images
运行redis
docker run --name myredis -p 6379:6379 -d redis redis-server --appendonly yes
docker run表示运行的意思 –name myredis 表示起个名字叫myredis -p 6379:6379表示把服务器的6379映射到docker的6379端口,这样就可以通过服务器的端口访问docker的端口 -d 表示以后台服务形式运行redis redis redis-server --appendonly yes表示开启持久化缓存模式,可以存到硬盘
3、安装 MySQL
下拉MySQL镜像:
docker pull mysql:5.7.27
Docker运行MySQL:
docker run --name mymysql -e MYSQL_ROOT_PASSWORD=admin -d -p 3306:3306 mysql:5.7.27
4、安装 RabbitMQ
一行命令搞定,注意RABBITMQ_DEFAULT_PASS=password是设置密码的意思,这行命令中已经偷偷做了下拉镜像等操作:
docker run -d --hostname my-rabbit --name myrabbit -e RABBITMQ_DEFAULT_USER=root -e RABBITMQ_DEFAULT_PASS=admin -p 15672:15672 -p 5672:5672 rabbitmq:management
5、安装 ElasticSearch
下拉镜像操作省略:
启动:
docker run -p 9200:9200 -p 9300:9300 -d --name es_643 elasticsearch:6.4.3
进入镜像:
docker exec -it es_643 /bin/bash
安装中文分词插件:
./bin/elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.4.3/elasticsearch-analysis-ik-6.4.3.zip
退出并重启镜像
exit
docker restart es_643
6、构建项目的 Docker 镜像
我们使用命令到github上拉取项目:
下拉项目(eblog):
clone https://github.com/MarkerHub/eblog.git
进入文件夹:
cd eblog
打包:
mvn clean package -Dmaven.test.skip=true
将打好的jar包上传到 linux 服务器上!
接下来编写 DockerFile,它能将我们打包好的jar包代码构建成镜像:
FROM java:8
EXPOSE 8080
VOLUME /tmp
ENV TZ=Asia/Shanghai
RUN ln -sf /usr/share/zoneinfo/{TZ} /etc/localtime && echo "{TZ}" > /etc/timezone
ADD eblog-0.0.1-SNAPSHOT.jar /app.jar
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-jar","/app.jar"]
FROM java:8 表示基于jdk8环境 EXPOSE 8080 表示对外暴露的端口是8080 VOLUME /tmp 表示挂载到/tmp目录 ADD eblog-0.0.1-SNAPSHOT.jar /app.jar 表示把jar包复制到镜像服务里面的根目录,并改名称app.jar RUN bash -c ‘touch /app.jar’ 表示执行创建app.jar ENTRYPOINT [“java”,"-jar","/app.jar"] 表示执行启动命令java -jar
接下来,我们安装Dockrfile,然后用DockerFile把eblog-0.0.1-SNAPSHOT.jar构建成镜像:
构建镜像
docker build -t eblog .
查看镜像
docker images
这步骤完成之后,我们就可以在准备工作就已经完成啦,接下来,我们就直接启动我们的项目
7、运行项目镜像 完成项目启动
命令如下:
docker run -p 8080:8080 -p 9326:9326 --name eblog --link es_643:ees --link myrabbit:erabbit --link mymysql:emysql --link myredis:eredis -d eblog
-p 8080:8080 -p 9326:9326 :9326是因为即时聊天需要用到的ws端口 --link es:ees 表示关联容器,把容器es起别名为ees
查看eblog打印日志:
docker logs -f eblog
到此项目运行成功!
注意: 使用 DockerCompose 更简单
|