Docker发布线上项目

Docker发布线上项目

原文链接:HuiBlog

记录下自己在发布部署项目时的方法,和一些踩过的坑

这里的话,博客就是用的这种方式部署的

项目时用springboot写的,打包成了war包,打包成jar包的话部署更简单一点

第一步:打包项目

因为springboot的项目默认都是打包成jar包的,还有自带的tomcat容器,这里先修改打包方式

01:修改pom.xml中的打包方式

<packaging>war</packaging>

02:取消springboot自带的tomcat容器

  <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <!-- 移除嵌入式tomcat插件 -->
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
            </exclusions>
 </dependency>

03:配置插件

否则会提示缺少web.xml文件

 <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <failOnMissingWebXml>false</failOnMissingWebXml>
                </configuration>
 </plugin>

04:修改springboot的启动类

在启动类的同级目录下创建SpringBootStartApplication.class

package com.hui.myblog;

import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;

/**
 * @author www.huiblog.top
 * @date 2020/9/24 19:22
 * QQ:2473181454
 * 概要:
 */
public class SpringBootStartApplication extends SpringBootServletInitializer {

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        // 注意这里要指向原先用main方法执行的Application启动类
        return builder.sources(MyblogApplication.class);
    }
}

05:打包

如果时IDEA的项目直接选择右侧的maven-clean-package即可

打包成功之后,会在target目录下生成一个war包的项目。

第二步:部署

部署需要的设备:

  1. 远程linux主机(这里博主买的是阿里的ecs服务器)

  2. 有一定的linux基础(会简单的几个命令就行,比如mkdir等)

  3. 已经备案好的域名

    如果上述都具备的话,那我们开始接下来的部署

01:Docker中安装自己项目涉及到的镜像

这里的话博主只用到了tomcat,mysql,nginx

下载镜像,配置镜像,启动容器这里博主就不废话了

不会的可以看下这篇文章:Docker简单使用

这里记录下配置tomcat镜像步骤,因为这里博主遇到了大坑

① 拉取镜像:

这里博主选择的是tomcat7.0

docker pull tomcat:7.0
② 启动镜像容器:
docker run -it -p 8888:8080 -v /myproject/myblog:/webapps -v /myproject/myblog/tomcatlog:/logs tomcat:7.0 /bin/bash

指令解释:

  1. -it:以守护进程的方式运行

  2. -p:注意这里是小写的p,大写的P会随机分配端口号,这里是将容器内部的8080端口映射到外部的8888,对开外放8888端口

  3. -v:设置挂在目录

    a:-v /myproject/myblog:/webapps 设置自己本机myblog下的项目和tomcat容器中webapps下的文件挂载起来

    b:-v /myproject/myblog/tomcatlog:/logs 设置自己本机tomcatlog下的日志和tomcat容器中logs下的日志挂载起来


好的,运行到这一步,docker中的操作结束,接下来发布项目

02:将自己的项目传到远程主机上

这里可以选择用finallshell,或者xftp都可以

博主用的是finallshell,直接进入之前设置的挂在目录/myproject/myblog,放自己的war包项目即可

注意:这里不用自己解压,tomcat容器会自动解压自己的war包项目

项目放好以后就可以重新启动下tomcat容器了,这会访问项目可以直接通过公网ip:端口号/项目名称即可访问了

第三步:配置nginx反向代理

项目部署好了以后,现在只能通过公网ip:端口/项目名称访问,但是一般的线上项目都是用过域名来访问的,这里就需要设置下nginx的反向代理

博主这里刚开始是在docker容器中下载的nginx镜像,配置了好久,一直不成功,之后有测试了在远程主机中通过yum自己下载一个nginx来配置,最后还是不成功,到这里,差点都想放弃了,直接通过jar包来部署,但是,多学一点,总没坏处,以后遇到了还能解决。

所以,最后直接在服务器中下载一个nginx的压缩包,自己来安装,最后成功了,详细步骤如下

01:下载压缩包

这里博主自己之前学的时候,电脑上有nginx压缩包,就直接传给了服务器

02:解压缩nginx
tar -xvf 压缩包名称
03:下载nginx的依赖
yum -y install make zlib zlib-devel gcc-c++libtool openssl openssl-devel
04:安装

首先进去你的解压后的nginx的目录,输入以下指令

./configure

执行结束后,没有error证明一切正常,之后再输入

make && make install

好了,nginx安装结束

05:启动nginx服务

nginx安装成功后,安装目录再/usr/local/nginx

进入目录:

#启动nginx服务
cd /usr/local/nginx/sbin/nginx

服务启动后,可以通过公网ip:80来进行访问下,如果出现了nginx的错误页面,证明一切正常,没有出现,解决方法如下:

  1. 开放esc服务器的安全组80端口
  2. 关闭服务器的防火墙

防火墙指令如下:

  1. 查看firewall服务状态

    systemctl status firewalld

    出现active:active(running)高亮显示表示是启动状态

    出现active:inactive(dead)灰色表示停止,这里看单词也行

  2. 查看firewall状态

    firewall-cmd --state

  3. 开启、重启、关闭firewalld服务

    开启:service firewalld start

    关闭:service firewalld stop

    重启:service firewalld restart

  4. 查看防火墙规则

    firewall-cmd --list-all

  5. 查询,开放,关闭端口

    查询:firewall-cmd --query-port=8080/tcp

    开放:firewall-cmd --permanent --add-port=80/tcp

    移除:firewall-cmd --permanent --remove-port=8080/tcp

    重启防火墙(修改配置后需要重启防火墙):firewall-cmd --reload

  6. 参数解释

    1、firwall-cmd:是Linux提供的操作firewall的一个工具;

    2、–permanent:表示设置为持久

防火墙关闭后访问应该就没什么问题了,如果依旧无法访问,可以再评论区留言,或者联系博主一起研究

06:配置nginx反向代理(重点,大坑)

首先进入自己的nginx配置文件目录,如果你的安装方法和我一样,那路径应该也是相同的

cd /usr/local/nginx/conf

进入之后可以看到有个nginx.conf文件

upstream tdl  {
	    server 这里的查看方式会在下面指出:8080[切记这里不要写/项目名称];
	}
	
    server {
        listen       80;
   		server_name  公网ip;
	    location / {
	        proxy_pass   http://tdl;
	    	}
    }

tdl中的server的地址是你docker容器中已经启动的tomcat容器的地址,这里博主理解的是每一个容器都相当于是一个小型独立的centos虚拟机,切记不要觉得这会项目通过公网ip:端口号/项目名称可以访问,就直接写成这样,切记不可。查看方式如下:

  1. 进入已经启动的tomcat容器里面

    docker exec -it 容器id /bin/bash

  2. 查看自己当前容器的host地址

    cd /etc/hosts

    输入之后会在最下面有一个172开头的地址

  3. 退出容器:

    ctrl + p +q

配置tomcat根目录直接访问项目方法:

最简单的:

将webapp下的ROOT文件删除,将自己的项目名称改成ROOT即可

清理电脑的dns缓存

cmd运行ipconfig /flushdns

好的,一直到这里,项目部署完成,现在就可以通过域名来直接访问你的项目了,再部署过程中真的是巨坑,网络环境,缓存,各种各样的问题,不过,最后项目跑起来了,也学到了很多小知识,最后还是很开心的。

这里的话,这样部署还是有很多问题,nginx还是没有再docker容器中,docker需要一次启动3个容器

其实可以将自己项目运行需要的镜像通过dockerfile整合到一个容器中去,这样就方便了很多,具体方案会在下一篇博客指出。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值