数据库-day02

一.课程回顾

1.数据库的产品介绍
    RDBMS:oracle,mysql,PG,mssql
    NOSQL:Redis,MongoDB,es,memcached
2.MySQL分支
    oracle
    mariadb
    percona
    rds,polardb,OB
3.MySQL版本选择
    GA 6-12月
    5.6:5.6.38    2017-9-13
    5.7:5.7.20    2017-9-13
4.安装-初始化
    5.6:/usr/local/mysql/scripts/mysql_install_db
    5.7:mysqld --initialize-insecure
5.c/s
    tcp/ip:mysql -uroot -p123 -h10.0.0.51 -p3306
    socket:mysql -uroot -p123 -S /tmp/mysql.sock
6.MySQLD的程序结构
    连接层:提供链接协议,用户验证,提供链接线程
    sql层:语法,语义,权限,解析,优化,执行
    存储引擎层:从磁盘上提取数据
7.逻辑结构
    库:库名字,库属性
    表:表名,列,行,属性
8.物理结构
    宏观:
        库:目录
        表:  myisam:frm,myi,myd
            innodb:frm ibd
    微观:
        段
        区
        页
9.用户权限
    create user 添加用户
    drop user  删除用户
    alter user  更改用户
    mysql.user 查找用户
    grant  创建并授权
    remoke  回收权限

二.8.0.16版本二进制安装

1.上传安装包并且解压
2.修改版本名称,并授权
    ![图片.png](https://upload-images.jianshu.io/upload_images/18572205-64364106e507c763.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

跨版本升级:

1.不要挎多个版本
2.5.7之前的升级  mysql_upgrade(需要执行这条命令)
5.6升级到5.7
    1.安装新版本软件
    2.改软连接或配置文件中的basedir
    3.用5.7的软件启动5.6的数据
    4.mysql_upgrade -uroot -p123 -S /tmp/mysql.sock
    注意:备份
  5.7之后的直接下载版本  然后启动 数据自动升级
    升级之前必须停掉数据库进行备份
跨版本升级:
    1.不要挎多个版本
    2.看好版本

三.MySQL的连接管理

1.MySQL linux中的连接协议
socket:本地登录,提前创建好localhost相关用户
TCPIP:远程登录,提前创建好远程用户
2.MySQL客户端
MySQL:[root@db01 ~]# mysql -uroot -p -S /tmp/mysql.sock
                      mysql -uoldboy -p -h10.0.0.51 -P3306

注意:
1.不要连接时把密码写到命令行上
2.写博客的时候,要脱敏
sqlyog:
navicat:

四.MySQL的启动关闭

1.sysv
service mysqld start/stop/restart/status
2.systemctl
systemctl start/stop/restart/status mysqld
3.手工启动方式(维护性操作时)
/etcinit.d/mysqld  ----》 /usr/local/mysql/bin/mysqld_safe ------>/usr/local/mysql/bin/mysqld
例子:管理员用户root@'localhost' 密码丢失
1.通过跳过授权表+跳过TCP/IP的参数。启动数据库
    --skip-grant-tables :跳过授权表,链接层关闭验证模块。
    --skip-networking:关闭链接层TCP/IP,只留socket文件链接
关闭数据库:systemctl stop mysqld.service
跳过授权表登录:mysqld_safe --skip-grant-tables --skip-networking &
2.无密码登录
3.修改密码
    flush privileges;
    alter user  root@'localhost' identified by '123';
 4.正常重启数据库
systemctl restart mysqld
图片.png
4.mysql的其他关闭方式

mysqladmin -uroot -p -S /tmp/mysql.sock shutdown

五.初始化配置

1.配置文件(/etc/my.cnf)*****
[root@db01 ~]# mysqld --help --verbose |grep my.cnf
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf
叠加关系 如果四个配置文件都有  就会执行最后一个文件~/.my.cnf
自己定义默认位置:mysqld或者mysqld_safe 加入 --defaults-file=/opt/oldboy/conf
02.配置文件内容
1.影响范围
    服务端启动和工作  
    本地客户端连接(socket)
2.内容结构
    标签:
        服务端:[mysqld] [mysqld_safe] [server]
        客户端:[mysql] [mysqldump] [client]
    配置参数:
        参数名=值
#服务端
[mysqld]  ... 标签
user=mysql
basedir=/usr/local/mysql  ....软件的路径
datadir=/data/mysql/data  ....目录的路径
#服务端的套接字文件
socket=/tmp/mysql.sock
 服务端参数修改  需要重启
#客户端
[mysql]
socket=/tmp/mysql.sock
2.命令行***
3.编译安装*

六.多实例

1.规划
01.端口:3307,3308,3309
02.数据:/data/330{7..9}/data    
03.配置文件:/data/330{7..9}/my.cng
    Port=3307/3308/3309
    server_id=7/8/9
    datadir=/data/330{7..9}/data 
    socket=/tmp/mysql330{7..9}.sock
2.干活
01.创建相关目录并授权
    mkdir -p /data/330{7..9}/data
    chown -R mysql.mysql /data/*
02.初始化数据
   mv /etc/my.cnf /tmp
    mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/3307/data  
    mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/3308/data  
    mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/data/3309/data
03.准备配置文件
cat > /data/3307/my.cnf <<EOF
[mysqld]
user=mysql
basedir=/usr/local/mysql
datadir=/data/3307/data
port=3307
server_id=7
socket=/tmp/mysql3307.sock
EOF

cat > /data/3308/my.cnf <<EOF
[mysqld]
user=mysql
basedir=/usr/local/mysql
datadir=/data/3308/data
port=3308
server_id=8
socket=/tmp/mysql3308.sock
EOF

cat > /data/3309/my.cnf <<EOF
[mysqld]
user=mysql
basedir=/usr/local/mysql
datadir=/data/3309/data
port=3309
server_id=9
socket=/tmp/mysql3309.sock
EOF
 04.准备启动脚本
cat > /etc/systemd/system/mysqld3307.service <<EOF
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/data/3307/my.cnf
LimitNOFILE = 5000
EOF

cat > /etc/systemd/system/mysqld3308.service <<EOF
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/data/3308/my.cnf
LimitNOFILE = 5000
EOF

cat > /etc/systemd/system/mysqld3309.service <<EOF
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/data/3309/my.cnf
LimitNOFILE = 5000
EOF
5.启动多实例并验证状态
[root@db01 ~]# systemctl start mysqld3307
[root@db01 ~]# systemctl start mysqld3308
[root@db01 ~]# systemctl start mysqld3309
[root@db01 ~]# netstat -tulnp|grep mysqld
tcp6       0      0 :::3306                 :::*                    LISTEN      8692/mysqld         
tcp6       0      0 :::3307                 :::*                    LISTEN      8912/mysqld         
tcp6       0      0 :::3308                 :::*                    LISTEN      8932/mysqld         
tcp6       0      0 :::3309                 :::*                    LISTEN      8980/mysqld         
小作业:
mysql_multi 实现多实例环境
https://dev.mysql.com/doc/refman/5.7/en/mysqld-multi.html
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容