MySQL 安装和基本使用

时间:2024-10-22 08:56:35

MySQL 介绍

MySQL 的特性

  • MySQL 是基于开源协议发布的,可以免费使用,也可以基于源码进行二次开发。

  • MySQL 使用标准 SQL 语言进行管理。

  • MySQL 可以运行于多个系统上,具有跨平台特性,并且支持多种语言。

  • MySQL 使用插件式存储引擎,不同的存储引擎,有着不同的功能和特性,使用者可以根据需要灵 活选择。

  • MySQL 基于单进程,多线程的模式进行工作。

  • MySQL 提供了大量的测试组件和诸多的扩展

MySQL 安装

MySQL 主流的三种安装方式

安装方式 说明
包管理器进行安装 配置好 MySQL 仓库源,用包管理器进行在线安装
二进制包本地安装 下载己编译完成的压缩包,展开至特定路径,并经过简单配置后即可使用
源码编译安装 下载指定版本源码在本地进行编译安装

包管理器进行安装
yum list mysql mysql-server

#安装 mysql-server,会自动安装客户端包
yum install -y mysql-server

#服务状态
systemctl status mysqld.service
 
#启动服务
systemctl enable --now mysqld.service

#自动创建的账户
 getent passwd mysql
mysql:x:27:27:MySQL Server:/var/lib/mysql:/sbin/nologin

#查看家目录
ll /var/lib/mysql
二进制包安装

这里的二进制包是指己经编译完成,以压缩包提供下载的文件,下载到本地之后释放到自定义目录,再进行配置即可

#安装依赖
yum -y install libaio numactl-libs ncurses-compat-libs

#创建组和用户
groupadd -r mysql
useradd -r -g mysql -s /sbin/nologin mysql

#下载包
wget https://downloads.mysql.com/archives/get/p/23/file/mysql8.0.20-linux-glibc2.12-x86_64.tar.xz

#解压至指定目录,这个目录只能写 /usr/local/
tar xf mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz -C /usr/local/
cd /usr/local/
ln -s mysql-8.0.20-linux-glibc2.12-x86_64/ mysql
chown -R root.root mysql/

#创建环境变量
echo 'PATH=/usr/local/mysql/bin:$PATH' >/etc/profile.d/mysql.sh
. /etc/profile.d/mysql.sh

echo $PATH
/usr/local/mysql/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

#创建主配置文件
vim /etc/my.cnf
[mysqld]
datadir=/data/mysql
skip_name_resolve=1
socket=/data/mysql/mysql.sock
log-error=/data/mysql/mysql.log
pid-file=/data/mysql/mysql.pid
[client]
socket=/data/mysql/mysql.sock

#创建数据目录
mkdir -pv /data/mysql

#初始化,本地root用户空密码
#如果使用 --initialize 选项会生成随机密码,要去 /data/mysql/mysql.log中查看

mysqld --initialize-insecure --user=mysql --datadir=/data/mysql

#加启动脚本
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

chkconfig --add mysqld

#启动服务
systemctl start mysqld.service
源码编译安装

源码编译安装与前面的二进制包安装相比较,只多了编译过程

#安装依赖
yum -y install gcc gcc-c++ cmake bison bison-devel zlib-devel libcurl-devel libarchive-devel boost-devel ncurses-devel gnutls-devel libxml2-devel openssl-devel libevent-devel libaio-devel perl-Data-Dumper

#创建用户
useradd -r -s /sbin/nologin -d /data/mysql mysql

#创建目录,修改权限
mkdir -pv /data/mysql
chown mysql.mysql /data/mysql

#下载源码
wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.6.51.tar.gz
tar xf mysql-5.6.51.tar.gz
cd mysql-5.6.51

cmake . -DCMAKE_INSTALL_PREFIX=/apps/mysql -DMYSQL_DATADIR=/data/mysql/ -DSYSCONFDIR=/etc/ -DMYSQL_USER=mysql -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DWITHOUT_MROONGA_STORAGE_ENGINE=1 -DWITH_DEBUG=0 -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_LIBWRAP=0 -DENABLED_LOCAL_INFILE=1 -DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci

make -j 2 && make install

#配置环境变量
echo 'PATH=/apps/mysql/bin:$PATH' > /etc/profile.d/mysql.sh
. /etc/profile.d/mysql.sh

#初始化
cd /apps/mysql/
./scripts/mysql_install_db --datadir=/data/mysql/ --user=mysql

#生成配置文件
cp -b /apps/mysql/support-files/my-default.cnf /etc/my.cnf

#生成服务脚本
cp /apps/mysql/support-files/mysql.server /etc/init.d/mysqld

#加开机启动项
chkconfig --add mysqld

#启动服务
service mysqld start

MySQL 多实例

拿 MySQL 数据库来说明,就是在一台服务器上运行多个 MySQL 服务端进程,每个进程监听一个端口 (3306,3307,3308),维护一套属于其自己的配置和数据,客户端使用不同的端口来连接具体服端 进程,从而实现对不同的实例的操作

多实例的优点

  • 节约硬件资源:在某些场景下(比如说测试,调研,新旧业务并存等),需要配置不同的 MySQL 数据库版本,而又没有足够多的服务器资源,则可以选择在一台服务器上用不同的版本实现多开来 满足需求

  • 便于对比:在一个完全相同的硬件环境中,运行不同的 MySQL 版本,使用相同的参数进行测试, 调研时,可以最大程度的减少外部环境因素的影响,便于得出更准确的结论

  • 便于管理:在一台服务器上运行多个实例,同理,只需要在这一台服务器上配置安全规则,就可以完成对多个实例的访问授权,而且对于数据库的备份,停启等工作,也只需要在这一台服务器上完成

多实例的缺点

  • 资源抢占:一台服务器上运行多个服务实例,资源总量恒定,一个实例占用的资源无法被另一个实 例所使用,在这种情况下,服务性能会受到影响,无法体现 MySQL 服务的实际性能

  • 存在单点风险:一台服务器上部署多个服务实例,如果该服务器当机,则这多个服务实例都会受影响

MySQL 组成和常用工具

MySQL 主要组成

mysql 基于 C/S 模式提供服务,主要有客户端程序和服务端程序组成,另外还有一些管理工具

服务端主要组成 客户端主要组成

程序 功能
mysqld_safe 安全启动脚本
mysqld 服务端程序,是mysql服务的核心程序
mysqld_multi 多实例工具

客户端主要组成

程序 功能
mysql 基于mysql 协议的交互式 CLI 工具
mysqldump 备份工具
mysqladmin 服务端管理工具
mysqlimport 数据导入工具

MyISAM存储引擎的管理工具

程序 功能
myisamchk 检查MyISAM库
myisampack 打包MyISAM表,只读

MySQL 客户端使用

MySQL 服务基于 C/S 架构,用户主要使用客户端工具来与远程服务端进行连接,从而与 MySQL 服务进 行交互

MySQL 客户端常用选项

mysql [OPTIONS] [database]

#常用选项
-V|--version #显示客户端版本
-u|--user=name #指定远程连接用户名
-p|--password[=name] #指定密码, 默认为空
-h|--host=host     #指定服务端主机
-P|--port=port #指定端口,默认3306
-S|--socket=name #指定连接时使用的socket文件,该文件在服务端启动后生成
-D|--database=db #指定数据库
-H|--html         #以html格式输出
-X|--xml           #以xml格式输出
-t|--table #以table格式输出,默认项
-E|--vertical #垂直显示执行结果
-v|--verbose #显示详细信息,配合 -t 选项
-C|--compress #启用压缩
-G|--named-commands #启用长命令
-e|--execute=sql #执行完就退出,非交互式运行
--prompt=name #修改命令提示符
--line-numbers     #输出行号
--print-defaults #打印参数列表,放在最前面
--connect-timeout=N #连接超时时长,单位S
--max-allowed-packet=N #一次查交互发送或反回数据的大小,默认16MB,最大值为1GB,最小值为4096字节

MySQL 客户端常用命令

MariaDB [(none)]> CMD

#常用命令
?|\? #显示帮助
help|\h #显示帮助
clear|\c #清屏,直接使用无法生效,要配合 system 命令使用
exit|\q #退出客户端
quit|\q #退出客户端
status|\s #显示当前状态
use|\u #切换数据库
system|\! #调用系统命令
prompt|\R #修改提示符
source|\. #执行SQL脚本文件
connect|\r #客户端重新连接,使用之前的参数
tee|\T #设置文件名,将输出结果同时保存一份到指定文件
notee|\t #不保存输出结果至文件
delimiter|\d #自定义SQL语句分隔符
go|\g #将语句送到服务端执行
ego|\G #将语句送到服务端执行,垂直显示
print|\p #输出语句,但不执行
warnings|\W #总是输出告警信息
nowarning|\w #不输出告警信息
charset|\C #设置编码
edit|\e #先编辑SQL语句,再执行


mysql> \s
--------------
mysql  Ver 8.0.39-0ubuntu0.24.04.2 for Linux on x86_64 ((Ubuntu))

Connection id:		8				#连接ID
Current database:					#当前使用的数据库
Current user:		root@localhost	#连接时的用户名
SSL:			Not in use			#是否使用ssl
Current pager:		stdout
Using outfile:		''
Using delimiter:	;
Server version:		8.0.39-0ubuntu0.24.04.2 (Ubuntu)
Protocol version:	10				#协议版本
Connection:		Localhost via UNIX socket
Server characterset:	utf8mb4		#服务器编码
Db     characterset:	utf8mb4		#数据库编码
Client characterset:	utf8mb4		#客户端编码
Conn.  characterset:	utf8mb4
UNIX socket:		/var/run/mysqld/mysqld.sock		#连接使用的socket 文件
Binary data as:		Hexadecimal		
Uptime:			7 hours 3 min 21 sec	#服务器运行时长

Threads: 2  Questions: 5  Slow queries: 0  Opens: 119  Flush tables: 3  Open tables: 38  Queries per second avg: 0.000#性能相关内容

在配置文件中修改提示符

vim /etc/my.cnf.d/client.cnf

[client]
prompt=(\\u@\\h) [\\d]>\\

#提示符中可用的变量
\C #计数器
\D #年月日时分秒
\d #当前使用的数据库
\h #服务器主机名
\l #命令分隔符,默认;
\m #当前时间,分钟
\n #换行
\O #月份,以英文显示
\o #月份,数字显示
\P #pm/am
\R #小时,24小时制
\r #小时,12小时制
\S #分号
\s #秒,数字显示
\t #tab键
\U #客户端用户名和主机
\u #客户端用户名
\v #服务端版本
\w #星期几,英文显示
\Y #年份,四位,数字显示
\y #年份,两位,数字显示

执行sql脚本

\. /root/test.sql

source /root/test.sql

mysqladmin 工具

mysqladmin 也是用于管理 mysql 服务的本地工具

mysqladmin [OPTIONS] command command...

#常用选项
-?|--help         #显示帮助信息
-V|--version       #显示客户端版本
-f|--force         #删库时不确认
-C|--compress     #启用压缩
-h|--host=name     #指定服务器地址
-u|--user=name     #指定用户名
-p|--password[=name] #指定连接服务器的密码
-P|--port=N       #指定连接端口,默认3306
-l|--local         #在本地执行,语句不写入binlog
-b|--no-beep       #执行出错时不发出告警音
-s|--silent       #如果无法连接,则静默退出
-c|--count=N       #总共执行多少次,配合-i选项使用
-i|--sleep=N     #持续执行命令,间隔N秒执行一次
-S|--socket=name #指定连接时使用的socket文件
-w|--wait[=#]     #如果连接失败,是否等待重试,如果指定了具体数字,则表示重试几次
--plugin-dir=name   #客户端查件目录
--print-defaults         #显示运行参数,
--defaults-file=path     #从指定文件中读取选项
--connect-timeout=N #指定连接超时时长
--shutdown-timeout=N #指定关机超时时长
--protocol=name     #指定连接方式 (tcp|socket|pipe|memory)
--ssl                   #使用ssl安全功能


#命令
create databasename #创建新的数据库
debug #开启调试模式,将调试信息写入log
drop databasename #删除指定数据库
extended-status         #显示扩展状态
flush-all-statistics   #刷新所有统计表
flush-all-status       #刷新状态和统计信息
flush-client-statistics #刷新客户端统计信息
flush-hosts           #刷新所有缓存的主机
flush-index-statistics #刷新索引统计信息
flush-logs             #刷新所有日志
flush-privileges       #刷新访问权限
flush-binary-log       #刷新二进制日志
flush-engine-log       #刷新引擎日志
flush-error-log         #刷新错误日志,开一个新日志文件
flush-general-log       #刷新执行日志
flush-relay-log         #刷新中继日志
flush-slow-log         #刷新慢查询日志
flush-status           #清除状态变量
flush-table-statistics #清除表统计信息
flush-tables           #刷新所有表,会强制关闭己打开的表
flush-threads           #刷新线程缓存
flush-user-statistics   #刷新用户统计信息
flush-user-resources   #刷新用户资源
kill id,id,... #关闭指定的线程
password [new-password] #修改密码
old-password [new-password] #修改密码时指定旧密码
ping #心跳检测
processlist #显示活动线程列表
reload #刷新授权信息
refresh #刷新所有数据表,重新打开日志文件
shutdown #关闭服务
status #简短显示服务端状态
start-slave #开启主从同步
stop-slave #停止主从同步
variables             #显示服务端所有变量
version #显示客户端和服务端版本

mycli 工具

MyCLI 是基于 Python 开发的 MySQL 的命令行工具,具有自动完成和语法突出显示功能

yum install python38

#使用国内源
pip3.8 config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple
pip-3.8 install mycli

mycli -u用户名 -p密码