文章目录
- 实战章节:在Linux上部署各类软件
- 一 MySQL数据库管理系统安装部署【简单】
- 二 Tomcat安装部署【简单】
- 三 Nginx安装部署【简单】
- 四 RabbitMQ安装部署【简单】
- 五 Redis安装部署【简单】
- 六 ElasticSearch安装部署
- 七 集群化环境前置准备
- 八 Zookeeper集群安装部署
- 九 Kafka集群安装部署
- 十 大数据集群(Hadoop生态)安装部署
- 十一 大数据NoSQL数据库HBase集群部署
- 十二 分布式内存计算Spark环境部署
- 十三 分布式内存计算Flink环境部署
- 十四 运维监控Zabbix部署
- zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -p Zabbix1234!
- 十五 运维监控Grafana部署
实战章节:在Linux上部署各类软件
tar -zxvf各个选项的含义
tar -zxvf
是常见的 Linux 中用于解压 .tar.gz
文件的命令组合。以下是各个选项的详细含义:
字母 | 含义 |
---|---|
-z |
gzip:表示使用 gzip 压缩格式,解压 .tar.gz 文件时必须加上此选项。 |
-x |
extract:表示解压归档文件(从压缩包中提取文件和目录)。 |
-v |
verbose:显示详细的解压过程,将解压的每个文件名称输出到屏幕,方便用户查看进度。 |
-f |
file:指定要操作的文件(后面必须跟上目标文件的名称,比如 file.tar.gz )。 |
常见组合
- 解压
.tar.gz
文件
tar -zxvf file.tar.gz
解压 file.tar.gz
文件到当前目录。
过程会显示解压出的文件和目录名称。
- 解压
.tar.gz
文件到指定目录
tar -zxvf file.tar.gz -C /path/to/directory
使用 -C
指定解压后的目标目录,例如 /path/to/directory
。
- 压缩目录为
.tar.gz
文件
tar -zcvf file.tar.gz directory_name
压缩 directory_name
目录为 file.tar.gz
。
选项补充
选项 | 功能 |
---|---|
-c |
create:创建一个归档文件(打包文件)。 |
-t |
list:列出归档文件的内容,而不解压。 |
-C |
directory:解压文件到指定目录。 |
--exclude |
排除指定文件或目录不加入归档。 |
具体示例
查看 .tar.gz
文件内容
tar -ztvf file.tar.gz
显示文件内容而不解压,列出文件的结构。
只解压指定的文件
tar -zxvf file.tar.gz file1 file2
仅解压 file1
和 file2
两个文件。
总结
tar -zxvf
的含义可以分解为:
z:处理 gzip
压缩。
x:解压文件。
v:显示详细解压过程。
f:指定操作的文件。
这是一个常用的 Linux 解压命令组合,用于处理 .tar.gz
文件。根据需要,您可以灵活添加其他选项来完成复杂的压缩或解压操作!
为什么学习各类软件在Linux上的部署
在前面,我们学习了许多的Linux命令和高级技巧,这些知识点比较零散,同学们跟随着课程的内容进行练习虽然可以基础掌握这些命令和技巧的使用,但是并没有一些具体的实操能够串联起来这些知识点。
前置要求
- 实战章节要求同学们务必全部学习前面的知识点,即:初识Linux、Linux基础命令、Linux权限管理、Linux高阶技巧这4个章节,请勿跳过前面的章节学习实战章节。
- 实战章节中会开启多台虚拟机,请尽量确保电脑的内存在:8GB(包含8GB)以上。如内存不足可以扩充内存条或购买阿里云、UCloud等云服务器临时使用(1个月多台低配服务器几十块左右)
对于云平台上购买服务器,可以参阅最后的章节(云服务)
注意
下面全部的软件安装的相关流程,90%都是取自软件自身的官方网站。
一个合格的程序员要有良好的信息收集能力哦
一 MySQL数据库管理系统安装部署【简单】
MySQL5.7版本在CentOS系统安装
注意:安装操作需要root权限
MySQL的安装我们可以通过前面学习的yum命令进行。
安装
- 配置yum仓库
# 更新密钥
rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022
# 安装Mysql yum库
rpm -Uvh http://repo.mysql.com//mysql57-community-release-el7-7.noarch.rpm
由于MySQL并不在CentOS的官方仓库中,所以我们通过上述rpm命令:
- <font style="color:rgb(119, 119, 119);">导入MySQL仓库的密钥</font>
- <font style="color:rgb(119, 119, 119);">配置MySQLQ的yum仓库</font>
- 使用yum安装MySQL
# yum安装Mysql
yum -y install mysql-community-server
- 安装完成后,启动MySQL并配置开机自启动
systemctl start mysqld # 启动
systemctl enable mysqld # 开机自启
MySQL安装完成后,会自动配置为名称叫做:<font style="color:rgb(119, 119, 119);background-color:rgb(243, 244, 244);">mysqld</font>
的服务,可以被systemctl所管理
检查MySQL的运行状态
- systemctl status mysqld
配置
主要配置管理员用户root的密码以及配置允许远程登录的权限。
- 获取MySQL的初始密码
# 通过grep命令,在/var/log/mysqld.log文件中,过滤temporary password关键字,得到初始密码
grep 'temporary password' /var/log/mysqld.log
- 登陆MySQL数据库系统
# 执行
mysql -uroot -p
# 解释
# -u,登陆的用户,MySQL数据库的管理员用户同Linux一样,是root
# -p,表示使用密码登陆
# 执行完毕后输入刚刚得到的初始密码,即可进入MySQL数据库
- 修改root用户密码
# 在MySQL控制台内执行
ALTER USER 'root'@'localhost' IDENTIFIED BY '密码'; -- 密码需要符合:大于8位,有大写字母,有特殊符号,不能是连续的简单语句如123,abc
- [扩展],配置root的简单密码
我们可以给root设置简单密码,如123456.
请注意,此配置仅仅是用于测试环境或学习环境的MySQL,如果是正式使用,请勿设置简单密码
# 如果你想设置简单密码,需要降低Mysql的密码安全级别
set global validate_password_policy=LOW; # 密码安全级别低
set global validate_password_length=4; # 密码长度最低4位即可
# 然后就可以用简单密码了(课程中使用简单密码,为了方便,生产中不要这样)
ALTER USER 'root'@'localhost' IDENTIFIED BY '简单密码';
- [扩展],配置root运行远程登录
默认情况下,root用户是不运行远程登录的,只允许在MySQL所在的Linux服务器登陆MySQL系统
请注意,允许root远程登录会带来安全风险
# 授权root远程登录
grant all privileges on *.* to root@"IP地址" identified by '密码' with grant option;
# IP地址即允许登陆的IP地址,也可以填写%,表示允许任何地址
# 密码表示给远程登录独立设置密码,和本地登陆的密码可以不同
# 刷新权限,生效
flush privileges;
- 退出MySQL控制台页面
# 退出命令
exit
# 或者通过快捷键退出:ctrl + d
检查端口
MySQL默认绑定了3306端口,可以通过端口占用检查MySQL的网络状态
- netstat -anp | grep 3306
至此,MySQL就安装完成并可用了,请妥善保存好MySQL的root密码。
MySQL8.0版本在CentOS系统安装
注意:安装操作需要root权限
安装
- 配置yum仓库
# 更新密钥
rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022
# 安装Mysql8.x版本 yum库
rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-2.noarch.rpm
- 使用yum安装MySQL
# yum安装Mysql
yum -y install mysql-community-server
- 安装完成后,启动MySQL并配置开机自启动
systemctl start mysqld # 启动
systemctl enable mysqld # 开机自启
MySQL安装完成后,会自动配置为名称叫做:<font style="color:rgb(119, 119, 119);background-color:rgb(243, 244, 244);">mysqld</font>
的服务,可以被systemctl所管理
检查MySQL的运行状态
- systemctl status mysqld
配置
主要修改root密码和允许root远程登录
- 获取MySQL的初始密码
# 通过grep命令,在/var/log/mysqld.log文件中,过滤temporary password关键字,得到初始密码
grep 'temporary password' /var/log/mysqld.log
- 登录MySQL数据库系统
# 执行
mysql -uroot -p
# 解释
# -u,登陆的用户,MySQL数据库的管理员用户同Linux一样,是root
# -p,表示使用密码登陆
# 执行完毕后输入刚刚得到的初始密码,即可进入MySQL数据库
修改root密码
- ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘密码’; – 密码需要符合:大于8位,有大写字母,有特殊符号,不能是连续的简单语句如123,abc
- [扩展],配置root的简单密码
我们可以给root设置简单密码,如123456.
请注意,此配置仅仅是用于测试环境或学习环境的MySQL,如果是正式使用,请勿设置简单密码
set global validate_password.policy=0; # 密码安全级别低
set global validate_password.length=4; # 密码长度最低4位即可
- 允许root远程登录,并设置远程登录密码
默认情况下,root用户是不运行远程登录的,只允许在MySQL所在的Linux服务器登陆MySQL系统
请注意,允许root远程登录会带来安全风险
# 第一次设置root远程登录,并配置远程密码使用如下SQL命令
create user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码!'; -- 密码需要符合:大于8位,有大写字母,有特殊符号,不能是连续的简单语句如123,abc
# 后续修改密码使用如下SQL命令
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
- 退出MySQL控制台页面
# 退出命令
exit
# 或者通过快捷键退出:ctrl + d
检查端口
MySQL默认绑定了3306端口,可以通过端口占用检查MySQL的网络状态
- netstat -anp | grep 3306
至此,MySQL就安装完成并可用了,请妥善保存好MySQL的root密码。
MySQL5.7版本在Ubuntu(WSL环境)系统安装
课程中配置的WSL环境是最新的Ubuntu22.04版本,这个版本的软件商店内置的MySQL是8.0版本
所以我们需要额外的步骤才可以安装5.7版本的MySQL
安装操作需root权限,你可以:
- 通过 sudo su -,切换到root用户
课程中选择这种方式操作
- 或在每一个命令前,加上sudo,用来临时提升权限
安装
- 下载apt仓库文件
# 下载apt仓库的安装包,Ubuntu的安装包是.deb文件
wget https://dev.mysql.com/get/mysql-apt-config_0.8.12-1_all.deb
- 配置apt仓库
# 使用dpkg命令安装仓库
dpkg -i mysql-apt-config_0.8.12-1_all.deb
弹出框中选择:<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">ubuntu bionic</font>
(Ubuntu18.04系统的代号是bionic,选择18.04的版本库用来安装)
弹出框中选择:<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">MySQL Server & Cluster</font>
弹出框中选择:<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">mysql-5.7</font>
最后选择:<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">ok</font>
- 更新apt仓库的信息
# 首先导入仓库的密钥信息
apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 467B942D3A79BD29
# 更新仓库信息
apt update
检查是否成功配置MySQL5.7的仓库
- apt-cache policy mysql-server
看到如图所示字样,即成功
- 安装MySQL5.7
# 使用apt安装mysql客户端和mysql服务端
apt install -f -y mysql-client=5.7* mysql-community-server=5.7*
弹出框中输入root密码并选择ok,密码任意,课程中以123456代替
再次输入root密码确认
- 启动MySQL
/etc/init.d/mysql start # 启动
/etc/init.d/mysql stop # 停止
/etc/init.d/mysql status # 查看状态
- 对MySQL进行初始化
# 执行如下命令,此命令是MySQL安装后自带的配置程序
mysql_secure_installation
# 可以通过which命令查看到这个自带程序所在的位置
root@DESKTOP-Q89USRE:~# which mysql_secure_installation
/usr/bin/mysql_secure_installation
1. <font style="color:rgb(51, 51, 51);">输入密码:</font>
2. <font style="color:rgb(51, 51, 51);">是否开启密码验证插件,如果需要增强密码安全性,输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">并回车,不需要直接回车(课程中选择直接回车)</font>
3. <font style="color:rgb(51, 51, 51);">是否更改root密码,需要输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">回车,不需要直接回车(课程不更改)</font>
4. <font style="color:rgb(51, 51, 51);">是否移除匿名用户,移除输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">回车,不移除直接回车(课程选择移除)</font>
5. <font style="color:rgb(51, 51, 51);">是否进制root用户远程登录,禁止输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">回车,不禁止直接回车(课程选择不禁止)</font>
6. <font style="color:rgb(51, 51, 51);">是否移除自带的测试数据库,移除输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">回车,不移除直接回车(课程选择不移除)</font>
7. <font style="color:rgb(51, 51, 51);">是否刷新权限,刷新输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">回车,不刷新直接回车(课程选择刷新)</font>
- 登陆MySQL
mysql -uroot -p
# 输入密码即可登陆成功
至此,在Ubuntu上安装MySQL5.7版本成功。
MySQL8.0版本在Ubuntu(WSL环境)系统安装
课程中配置的WSL环境是最新的Ubuntu22.04版本,这个版本的软件商店内置的MySQL是8.0版本
所以直接可以通过apt安装即可
注意,课程是以WSL获得的Ubuntu操作系统环境。
如果你通过VMware虚拟机的方式获得了Ubuntu操作系统环境,操作步骤不用担心,和课程中使用WSL环境是完全一致的
安装操作需root权限,你可以:
- 通过 sudo su -,切换到root用户
课程中选择这种方式操作
- 或在每一个命令前,加上sudo,用来临时提升权限
安装
- 如果已经安装过MySQL5.7版本,需要卸载仓库信息哦
# 卸载MySQL5.7版本
apt remove -y mysql-client=5.7* mysql-community-server=5.7*
# 卸载5.7的仓库信息
dpkg -l | grep mysql | awk '{print $2}' | xargs dpkg -P
更新apt仓库信息
- apt update
安装mysql
- apt install -y mysql-server
- 启动MySQL
/etc/init.d/mysql start # 启动
/etc/init.d/mysql stop # 停止
/etc/init.d/mysql status # 查看状态
- 登陆MySQL设置密码
# 直接执行:mysql
mysql
设置密码
- ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘password’;
退出MySQL控制台
- exit
- 对MySQL进行初始化
# 执行如下命令,此命令是MySQL安装后自带的配置程序
mysql_secure_installation
# 可以通过which命令查看到这个自带程序所在的位置
root@DESKTOP-Q89USRE:~# which mysql_secure_installation
/usr/bin/mysql_secure_installation
1. <font style="color:rgb(51, 51, 51);">输入密码:</font>
2. <font style="color:rgb(51, 51, 51);">是否开启密码验证插件,如果需要增强密码安全性,输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">并回车,不需要直接回车(课程中选择直接回车)</font>
3. <font style="color:rgb(51, 51, 51);">是否更改root密码,需要输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">回车,不需要直接回车(课程不更改)</font>
4. <font style="color:rgb(51, 51, 51);">是否移除匿名用户,移除输入</font>`<font style="color:rgb(51, 51, 51);background-color:rgb(243, 244, 244);">y</font>`<font style="color:rgb(51, 51, 51);">回车,不移除直接回车(课程选择移除)</font>