美文网首页
第八章(一)

第八章(一)

作者: 全麦土司 | 来源:发表于2020-02-17 15:00 被阅读0次

8.1 单元测试

图片.png
    1. 单元测试


      图片.png

测试方法之间不要有依赖关系。

因为我们的单元测试并不是仅仅使用一次。

  • 如何保证独立性呢?


    图片.png
  • 测试代码:


    图片.png
图片.png
  • 测试过程:
    直接运行整个测试类。

在测试的时候并不是输出,而是使用assert。


@RunWith(SpringRunner.class)
@SpringBootTest
@ContextConfiguration(classes = CommunityApplication.class)
public class SpringBootTests {

    @Autowired
    private DiscussPostService discussPostService;

    private DiscussPost data;

    @BeforeClass
    public static void beforeClass() {
        System.out.println("beforeClass");
    }

    @AfterClass
    public static void afterClass() {
        System.out.println("afterClass");
    }

    @Before
    public void before() {
        System.out.println("before");

        // 初始化测试数据
        data = new DiscussPost();
        data.setUserId(111);
        data.setTitle("Test Title");
        data.setContent("Test Content");
        data.setCreateTime(new Date());
        discussPostService.addDiscussPost(data);
    }

    @After
    public void after() {
        System.out.println("after");

        // 删除测试数据
        discussPostService.updateStatus(data.getId(), 2);
    }

    @Test
    public void test1() {
        System.out.println("test1");
    }

    @Test
    public void test2() {
        System.out.println("test2");
    }

    @Test
    public void testFindById() {
        DiscussPost post = discussPostService.findDiscussPostById(data.getId());
        Assert.assertNotNull(post);
        Assert.assertEquals(data.getTitle(), post.getTitle());
        Assert.assertEquals(data.getContent(), post.getContent());
    }

    @Test
    public void testUpdateScore() {
        int rows = discussPostService.updateScore(data.getId(), 2000.00);
        Assert.assertEquals(1, rows);

        DiscussPost post = discussPostService.findDiscussPostById(data.getId());
        Assert.assertEquals(2000.00, post.getScore(), 2);
    }

}

8.2 项目监控

图片.png

本节是关于项目上线之后如何对其进行监控,检测其是否稳定。


图片.png

localhost:8080/actuator/端点id。

按需配置端点,有被别人窃取的风险。
而且,应该加上权限控制,只有管理员可以进行访问,否则项目底层的内容就会被别人窥探到


图片.png

导入之后,启动应用就可以访问某些端点,但是不能访问所有的。

启动,访问端点:
以下两个端点是开放的:


图片.png
图片.png

还有其他的端点需要进行配置:


图片.png

返回当前应用中所有的bean:

图片.png 图片.png

每个端点展示出一方面的内容。

  • 自定义端点,监控个性化的内容


    图片.png

连接池是由spring容器进行管理的。


图片.png

注解表示这个方法是通过get请求进行访问的。

图片.png
  • 进行访问:


    图片.png
  • 对端点的路径进行权限管理:


    图片.png

8.3 项目部署

图片.png
    1. 安装软件
    1. 调整代码
    1. 进行部署
图片.png

右键,复制链接地址,然后使用linux命令行进行下载。

能用yum就使用yum下载,否则就是用安装包。


图片.png 图片.png

以上的这些是使用安装包进行下载的,剩下的需要使用yum进行安装。

本地向服务器传代码:


图片.png
图片.png
  • 安装解压缩工具unzip:
    使用yum方式进行安装
    yum install -y
    -y表示需要进行选择的地方全部都是yes。


    图片.png
  • 安装jre
    yum list java*
    //选择java-latest-openjdk.x86_64
    yum install -y java-latest-openjdk.x86_64
    java -version
    //查询版本

【使用yum安装工具,他会帮助我们将该配置的东西都配置完成,比较方便】

  • 安装maven
    cd root
    //到安装的目录下
    //通常我们将安装的程序放在opt目录下,因此我们将程序解压缩到哪个目录下面即可
    tar zxvf apache-maven-3.6.3-bin.tar.gz -C /opt


    图片.png

    拷贝:/opt/apache-maven-3.6.3 为了配置环境变量

  • 配环境变量
    将环境变量配置到/etc/profile文件夹下面
    vim /etc/profile【按i进入编辑模式】


    图片.png

    【含义:${}表示原本的值,使用:进行追加,也就将原来的path追加上maven的路径,再写回之前的path】


    图片.png

现在还没有生效
source /etc/profile
//文件生效
//打印出path变量
echo $PATH
mvn -version
//结果发现并不存在,命令配置错了,应该配置的是apache-maven下面的bin文件夹....

重新配置之后,没有问题了

  • 更改maven的配置文件,将其镜像设置成为阿里云。【也是为了不从中央仓库进行下载是吗?】
    //pwd查看当前在哪儿


    图片.png

    编辑里面的settings文件。
    将mirror配置成阿里云的,可以从本机进行拷贝

  • 安装mysql
    yum库的版本虽然稳定,但是版本太低了,因此我们使用自己下载的。我们将最新的下载之后就能够再yum库中搜索到了。


    图片.png
    图片.png

    再次搜索,内容就比较多了。


    图片.png
    装mysql服务器
    图片.png
    图片.png
    启动mysql的服务:

    启动使用yum安装的工具:


    图片.png

mysqld是指mysql服务器后台的名字
查看当前服务的状态:【active running 】


图片.png

安装的时候会生成一个临时的密码,密码在日志文件中。下面是从文件中搜素password这个单词。


图片.png
图片.png

登录mysql,并设置我们自己的密码:
mysql -uroot -p 'password'>登录
linux要求密码必须得有大写字母,特殊符号和数字。


图片.png
exit>重新登录
  • 导入数据


    图片.png

登录数据库,然后建库:
Create datebase community
use community
source /root/init-sql/-scheme.sql
source /root/init-sql/data.sql
source /root/init-sql/data.sql //还得导入定时任务所需的表
show tables
稍微调整user表的数据:
将带有localhost的headerUrl进行调整。


图片.png

再差一下就没有了


yum list redis*
yum install -y XXXXX
systemctl start redis//启动redis
systemctl status redis
//查看状态

绿了,是正确的。redis可以用了


图片.png

redis-cli
//访问redis

exit或者ctrl+c都可退出


装kafka
tar zxvf kafka_2.11-2.4.0.tgz -C /opt


图片.png

路径不需要更改。

  • 启动zookeeper【后台方式】
  • 启动kafka
    -查询主题


    图片.png

安装elasticSearch
tar zxvf elasticsearch-7.6.0-linux-x86_64.tar.gz -C /op
unzip -d /opt/elasticsearch-7.6.0-linux-x86_64/plugins/ik elasticsearch-analysis-ik


图片.png
图片.png
图片.png
  • 配置elasticsearch
图片.png
图片.png
  • 再改一下这个
    修改一下elasticearch占用java的内存空间,默认占用了1G,太大了。


    图片.png
    图片.png

elasticearch要求不能使用root用户启动,必须使用普通用户启动。

  • 新建一个普通用户
    /增加一个用户组
    groupadd cym
    //在组里建一个用户


    图片.png

设置用户权限,使之能访问ealsticsearch这个目录。以及能够访问tmp文件,里面记录的有日志文件等数据。


图片.png

为啥有个nowcoder:


图片.png

后台方式启动elasticsearch:


图片.png

su -
//切换回root用户

//访问elasticsearch服务,检查一个服务器是不是健康


图片.png

使用yum安装wkhtmltopdf

安装之后还不能使用,因为linux是一个纯服务器。他没有gui程序,没有能够处理界面的程序。
需要安装一个虚拟的gui服务器。
yum list xvfb
yum install -y xorg-x11-server-Xvfb.x86_64
/接下来测试一下能不能生成图片
cd /root/test

图片.png

我们可以字节写一个脚本,将前面的命令进行封装。
//复制前面的命令
cd /opt
//在这个文件中自己写一个脚本
vim wkhtmltoimage.sh//这是这个脚本的名字


图片.png

最后的引号里面表示参数的意思;
ll
//可以查看文件已经生成了,但是此时,这个文件只有读写权限,却没有执行权限。


图片.png

同样可以使用


安装tomcat
tar zvxf apache-tomcat-9.0.31.tar.gz -C /opt
配置环境变量


图片.png

然后通过pwd得到bin的路径,进行环境变量的配置。
保存之后,还得生效
source /etc/profile


图片.png
maven为什么重复了,没事儿。。。

启动tomcat

图片.png

我们部署的项目就放在webapp中:


图片.png

查看里面默认带的项目:


图片.png

yum安装ngix
yum install -y nginx.x86_64
需要进行配置才能让nginx分发请求给tomcat
vim /etc/nginx/nginx.conf
主要是配置里面的server
配置一下真实的服务器里面有多少个tomcat。
将文件里面的哪个服务器注销掉,不要删掉哦
用nginx代理服务器,叫做反向代理
代理浏览器的叫做正向代理,也叫做代理。
如果分发了三次请求都没有相应,就会认为是tomcat挂掉了,将其移除服务器的集合。过了30s之后再访问tomcat看看tomcat有没有活过来。


图片.png

下面再配置一个虚拟的服务器:
得有分号结尾;


图片.png

启动一下,因为是使用yum安装的,所以它的启动服务已经安装好了。
systemctl start nginx
systemctl status nginx
//出现了状态是running
此时直接访问ip,即可访问服务


装完了~~~

相关文章

网友评论

      本文标题:第八章(一)

      本文链接:https://www.haomeiwen.com/subject/zehmfhtx.html