8.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- 安装软件
- 调整代码
- 进行部署
右键,复制链接地址,然后使用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
-
再改一下这个
修改一下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
我们可以字节写一个脚本,将前面的命令进行封装。
//复制前面的命令
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,即可访问服务
装完了~~~
网友评论