学习笔记-MariaDB 部署及初始化设置 - CentOS
nanshan 2024-11-06 11:13 31 浏览 0 评论
前言
这几天因为看OpenStack教程,开始部署MariaDB,以前都是弄MySQL,已经习惯了,想着沿用以前的MySQL文档就好了
本来以为MariaDB和MySQL应该是完全一样的,结果一部署发现各种差异
最要命的是,两台相同系统的机器,一台部署一切顺利、另外一台怎么都装不上,报依赖错误
紧接着找初始化密码又找不到,初始化向导也找不到,MariaDB默认还不启动,需要手工启动,各种头大
好吧,我服了!重新装系统,一步步找原因,搭环境、写文档、编脚本……
MariaDB 安装前置准备
# 检查是否存在MariaDB
sudo rpm -qa | grep mariadb MariaDB
# 删除现存MariaDB
sudo yum -y remove mariadb* MariaDB*
# 检查是否存在MySQL
sudo rpm -qa | grep mysql
# 删除现存MySQL
sudo yum -y remove mysql*
# 删除旧配置文件
sudo rm -rf /etc/my.cnf
# 删除MySQL相关文件
sudo rm -rf /var/lib/mysql
安装 基本 依赖环境
# 安装 LSB
sudo yum install -y redhat-lsb
# 安装 YUM Utils
yum install -y yum-utils
# 安装 EPEL (不安装会产生依赖错误)
sudo yum install -y epel*
# 整合命令
sudo yum install -y redhat-lsb && sudo yum install -y yum-utils && sudo yum install -y epel*
未安装 EPEL 报错
安装 MariaDB 公钥
# 安装 MariaDB 公钥
rpm --import https://mirror.mariadb.org/yum/RPM-GPG-KEY-MariaDB
添加 MariaDB 安装源
# 手工创建 MariaDB.repo 文件
nano /etc/yum.repos.d/MariaDB.repo
# {
[mariadb]
name = MariaDB
baseurl = https://mirror.mariadb.org/yum/10.11.5/centos7-amd64/
gpgkey = https://mirror.mariadb.org/yum/RPM-GPG-KEY-MariaDB
enabled=1
gpgcheck=1
# }
# 自动创建 MariaDB.repo 文件
sudo cat <<EOF > /etc/yum.repos.d/MariaDB.repo
[mariadb]
name = MariaDB
baseurl = https://mirror.mariadb.org/yum/10.11.5/centos7-amd64/
gpgkey = https://mirror.mariadb.org/yum/RPM-GPG-KEY-MariaDB
enabled=1
gpgcheck=1
EOF
# 更新 YUM 源 缓存
sudo yum clean all && sudo yum makecache
安装 MariaDB 必要组件
# 安装 MariaDB
sudo yum install -y MariaDB-server \
MariaDB-client \
python2-PyMySQL
启动 MariaDB
# 启动 MariaDB 服务
sudo systemctl start mariadb.service
# 设置 MariaDB 为开机自启动
sudo systemctl enable mariadb.service
# 检查 MariaDB 服务运行状态
sudo systemctl status mariadb.service
# 查看端口运行情况 (未安装Net-Tools无法使用)
netstat -nlpt
# 查看 MariaDB 版本信息
sudo mariadb -V
# 停止 MariaDB
sudo systemctl stop mariadb.service
# 重启 MariaDB
sudo systemctl restart mariadb.service
MariaDB 运行状态
MariaDB 端口占用
MariaDB 版本信息
MariaDB初始化设置
使用 MariaDB Shell 进行初始化
# 默认密码
MariaDB 没有默认密码,初始化密码为空
# 设置初始化密码 (密码为P@ssw0rd)
mysqladmin -u root password "P@ssw0rd"
# 登录MySQL Shell
mariadb -uroot -p
mysql -uroot -p
# 修改MySQL密码 (密码为P@ssw0rd)
ALTER USER USER() IDENTIFIED BY 'P@ssw0rd';
# 检查系统用户访问权限
use mysql;
select user,host,plugin,authentication_string from mysql.user;
select user,host,plugin from mysql.user;
# 开启 root 远程登录权限,并刷新
update mysql.user set host='%' where user='root';
flush privileges;
# 退出MySQL Shell
exit
使用 MariaDB 初始化向导 进行初始化
# 数据库初始化向导 (新版本初始化向导名称已改)
sudo mariadb-secure-installation
# 确保MySQL服务器部署的安全。输入用户root的密码:(初始状态为空)
Enter current password for root (enter for none):
# 是否切换unix_socket身份验证 N
Switch to unix_socket authentication [Y/n]
# 是否更改 root 密码 Y
You already have your root account protected, so you can safely answer 'n'.
Change the root password? [Y/n]
# 输入新密码
New password:
# 重复输入新密码
Re-enter new password:
# 是否删除匿名用户 Y
Remove anonymous users? [Y/n]
# 是否禁止root用户远程登录 N
Disallow root login remotely? [Y/n]
# 是否删除test数据库 Y
Remove test database and access to it? [Y/n]
# 是否重新加载权限表 Y
Reload privilege tables now?
MariaDB 初始化向导 文字内容
NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!
In order to log into MariaDB to secure it, we'll need the current
password for the root user. If you've just installed MariaDB, and
haven't set the root password yet, you should just press enter here.
Enter current password for root (enter for none):
OK, successfully used password, moving on...
Setting the root password or using the unix_socket ensures that nobody
can log into the MariaDB root user without the proper authorisation.
You already have your root account protected, so you can safely answer 'n'.
Switch to unix_socket authentication [Y/n] n
... skipping.
You already have your root account protected, so you can safely answer 'n'.
Change the root password? [Y/n] Y
New password:
Re-enter new password:
Password updated successfully!
Reloading privilege tables..
... Success!
By default, a MariaDB installation has an anonymous user, allowing anyone
to log into MariaDB without having to have a user account created for
them. This is intended only for testing, and to make the installation
go a bit smoother. You should remove them before moving into a
production environment.
Remove anonymous users? [Y/n] Y
... Success!
Normally, root should only be allowed to connect from 'localhost'. This
ensures that someone cannot guess at the root password from the network.
Disallow root login remotely? [Y/n] n
... skipping.
By default, MariaDB comes with a database named 'test' that anyone can
access. This is also intended only for testing, and should be removed
before moving into a production environment.
Remove test database and access to it? [Y/n] Y
- Dropping test database...
... Success!
- Removing privileges on test database...
... Success!
Reloading the privilege tables will ensure that all changes made so far
will take effect immediately.
Reload privilege tables now? [Y/n] Y
... Success!
Cleaning up...
All done! If you've completed all of the above steps, your MariaDB
installation should now be secure.
Thanks for using MariaDB!
MariaDB 初始化向导 完整截图
测试 MariaDB
# 进入 MariaDB Shell
sudo mariadb -uroot -pP@ssw0rd
# 测试 MariaDB,刷新权限
flush privileges;
# 测试 MariaDB,列出数据库
show databases;
# 测试 MariaDB,查看用户
select user,host from mysql.user;
# 退出 MariaDB Shell
exit
↓ 没有任何技术含量 ↓
自动化安装脚本
#
# author: SRover Lee
# date: 2023/10/12
# Language: Shell Script
# description:
# 基于CentOS 7.9 定制简易化 MariaDB 安装脚本
# 1. 卸载所有MariaDB MySQL 安装版本残留
# 2. 安装 基本 依赖环境
# 3. 添加秘钥
# 4. 添加 官网 源
# 5. 重建源缓存
# 6. 安装 MariaDB 必要组件
# 7. 启动 MariaDB 服务
# 8. 设置 MariaDB 为开机自启动
# 9. 检查 MariaDB 服务运行状态
# 10. 查看端口运行情况
# 11. 显示 MariaDB 版本信息
#
#
echo ------------------- 卸载所有 MariaDB MySQL 安装版本残留 ------------------
# 检查是否存在MariaDB
sudo rpm -qa | grep mariadb MariaDB
# 删除现存MariaDB
sudo yum -y remove mariadb* MariaDB*
# 检查是否存在MySQL
sudo rpm -qa | grep mysql
# 删除现存MySQL
sudo yum -y remove mysql*
# 删除旧配置文件
sudo rm -rf /etc/my.cnf
# 删除MySQL相关文件
sudo rm -rf /var/lib/mysql
echo ------------------- 安装 基本 依赖环境 ---------------------------------
sudo yum install -y redhat-lsb && sudo yum install -y yum-utils && sudo yum install -y epel*
echo ------------------- 安装 MariaDB 公钥 ------------------------------
# 安装 MariaDB 公钥
rpm --import https://mirror.mariadb.org/yum/RPM-GPG-KEY-MariaDB
echo ------------------- 添加 MariaDB 官网源 -----------------------------
sudo cat <<EOF > /etc/yum.repos.d/MariaDB.repo
[mariadb]
name = MariaDB
baseurl = https://mirror.mariadb.org/yum/10.11.5/centos7-amd64/
gpgkey = https://mirror.mariadb.org/yum/RPM-GPG-KEY-MariaDB
enabled=1
gpgcheck=1
EOF
echo ------------------- 重建源缓存 --------------------------------------
sudo yum clean all && sudo yum makecache
echo ------------------- 安装 MariaDB 必要组件 ----------------------------
sudo yum install -y MariaDB-server \
MariaDB-client \
python2-PyMySQL
echo ------------------- 启动 MariaDB 服务 ------------------------------
# 启动 MariaDB
systemctl start mariadb.service
echo ------------------- 设置 MariaDB 为开机自启动 --------------------------
# 设置 MariaDB 为开机自启动
sudo systemctl enable mariadb.service
echo ------------------- 检查 MariaDB 服务运行状态 --------------------------
# 检查 MariaDB 服务运行状态
sudo systemctl status mariadb.service
echo ------------------- 查看端口运行情况 -----------------------------------
# 查看端口运行情况
netstat -nlpt
echo ----------------------------------------------------------------
# 显示提示信息
echo
echo
echo
echo
echo 已经完成 MariaDB 基础安装
echo 当前 MariaDB 环境 版本如下:
sudo mariadb -V
相关推荐
- 0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)
-
文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...
- ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes
-
为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...
- 生产环境starrocks 3.1存算一体集群部署
-
集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...
- 在CentOS上添加swap虚拟内存并设置优先级
-
现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...
- 国产深度(deepin)操作系统优化指南
-
1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...
- postgresql-15.4 多节点主从(读写分离)
-
1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...
- Docker 容器 Java 服务内存与 GC 优化实施方案
-
一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...
- 虚拟内存设置、解决linux内存不够问题
-
虚拟内存设置(解决linux内存不够情况)背景介绍 Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...
- Elasticsearch性能调优(5):服务器配置选择
-
在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...
- Es如何落地
-
一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...
- 针对Linux内存管理知识学习总结
-
现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...
- MySQL进阶之性能优化
-
概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...
- Linux Cgroups(Control Groups)原理
-
LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...
- linux 常用性能优化参数及理解
-
1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...
- 如何在 Linux 中使用 Sysctl 命令?
-
sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)