CentOS6安装配置python3及MySql5.1.73

最近租用了低配版的VPS,系统CentOS6.10 X64,1核512M内存。
系统默认安装python2.6.6,我需要使用python3。遂安装,记录安装过程。


查看当前操作系统内核信息

uname -a   
显示结果
#Linux Vultr.guest 3.10.0-862.3.2.el7.x86_64 #1 SMP Mon May 21 23:36:36 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux

查看centos系统版本

cat /etc/centos-release
#显示结果
#CentOS Linux release 7.5.1804 (Core) 

一、安装python3

1、安装依赖包
yum -y groupinstall "Development tools" yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel

2、下载所需版本的Python3
(所有版本的python都可以在https://www.python.org/ftp/python/上找到)
wget https://www.python.org/ftp/python/3.6.6/Python-3.6.6.tar.xz

3、创建存放目录
mkdir /usr/local/python3

4、解压压缩包,进入该目录,安装Python3
tar -xvf Python-3.6.6.tar.xz
cd Python-3.6.6
./configure --prefix=/usr/local/python3
make && make install #清除之前编译的可执行文件及配置文件
5、建软链接
ln -s /usr/local/python3/bin/python3 /usr/bin/python3
ln -s /usr/local/python3/bin/pip3 /usr/bin/pip3

这两句输进去是不会跳出来什么提示的

6、验证
python3 -V
pip3 -V

验证.png

7、制作成一键安装包pythoninstall.sh

#!/bin/bash
#一键安装python3.6.6脚本
echo '安装python3.6.6并设置python3'
echo '安装依赖库'
yum -y groupinstall "Development tools"
yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel
echo '下载python3.6.6'
wget https://www.python.org/ftp/python/3.6.6/Python-3.6.6.tar.xz
#创建安装目录
mkdir /usr/local/python3
#解压并安装
tar -xvf Python-3.6.6.tar.xz
cd Python-3.6.6
./configure --prefix=/usr/local/python3
make && make install
#创建软链接
ln -s /usr/local/python3/bin/python3 /usr/bin/python3
ln -s /usr/local/python3/bin/pip3 /usr/bin/pip3
echo '安装完毕!'

终端输入:bash pythoninstall.sh
一键安装python3搞定!


二、安装mysql5.1.73

1、查看有无安装过mysql
rpm -qa|grep mysql
或者
yum list installed mysql

2、查看有无安装包
yum list mysql*

3、安装mysql服务端
yum install mysql mysql-server yum install mysql-devel

4、启动&&停止
(1)设置数据库默认字符
在mysql配置文件/etc/my.cnf中加入default-character-set=utf8
nano /etc/my.cnf

(2)设置开机启动
chkconfig mysqld on chkconfig --list mysqld
查看mysql开机启动状态
chkconfig --list |grep mysqld
(3)启动mysql
service mysqld start

5、登录
(1)创建root管理员
mysqladmin -u root password 123456

(2)忘记密码(没实践过)
service mysqld stop mysqld_safe --user=root --skip-grant-tables mysql -u root use mysql update user set password=password("new_pass") where user="root"; flush privileges;

(3)查看mysql状态
service mysqld status
显示mysqld is running

6、远程访问
(1)修改localhost
更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改成"%"
mysql>use mysql;
mysql>update user set host = '%' where user = 'root';
mysql>select host, user from user;
mysql>FLUSH PRIVILEGES;

(2)指定授权(成功实践)
1)使用myuser/mypassword从任何主机连接到mysql服务器:

GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
FLUSH PRIVILEGES;

可以从别的机器上用mysql -umyuser -pmypassword -h192.168.1.XXX登录

2)使用myuser/mypassword从ip为192.168.225.166的主机连接到mysql服务器:

GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.166' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;

3)泛授权(未实践)

mysql -h localhost -u root
mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION; //赋予任何主机上以root身份访问数据的权限
mysql>FLUSH PRIVILEGES;

7、MySQL的几个重要目录
a、数据库目录
/var/lib/mysql/
b、配置文件
/usr/share /mysql(mysql.server命令及配置文件)
c、相关命令
/usr/bin(mysqladmin mysqldump等命令)
d、启动脚本
/etc/rc.d/init.d/(启动脚本文件mysql的目录)

8、卸载mysql
a、查找以前是否装有mysql
rpm -qa|grep -i mysql
b、删除mysql
yum remove mysql mysql-server mysql-libs compat-mysql51
rm -rf /var/lib/mysql
rm /etc/my.cnf

9、bug处理
[ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)]
解决方法:
(1)停止mysql服务器
service mysqld stop
(2)使用mysqld_safe命令在启动mysql,更新root账号的密码
mysqld_safe --user=mysql --skip-grant-tables --skip-networking &:
注:--skip-grant-tables:不启动grant-tables(授权表),跳过权限控制。
  --skip-networking :跳过TCP/IP协议,只在本机访问(从网上有些资料看,这个选项不是必须的。可以不用)
执行上面命令后,此会话窗口会出现无反应的状态,需要使用CTRL+C中断会话
(3)设置密码
mysql -u root mysql
mysql> update user set password=PASSWORD('12345')
-> where user='root' and host='root' or host='localhost';
flush privileges
(4)启动mysql服务
service mysqld start

三、实现远程登录mysql

要使得能从本地访问远程服务器mysql数据库,还需要对其授权。在服务器上我们需要做一些配置工作。

mysql -h localhost -u root -p
mysql>grant all privileges on *.* to 'root'@'%' identified by '123456' with grant option; 
mysql>flush privileges;

这句话的意思是将对所有的database(.)的所有的权限(如增删改查等)授予所有的主机(%)的root用户,这些用户的登陆密码为123456(可以和mysql的密码不一样)。
另外我们还需要关闭服务端的iptables:service iptables stop,然后就可以从本地机器上试着连接服务器的mysql了。
mysql -h 192.168.1.xx -u root -p123456
注意这里的-p后面的密码紧跟其后,不要有空格,否则123456会被当成数据库名称
如果你不想完全关闭iptables,我们还有另一个方法:为iptables增加一条接受远程访问该mysql的规则,开放端口权限(mysql使用端口3306)。
注意一定要将规则加在reject规则的前面,否则不会起到作用,连接就会照样报错。
看到信息 firewall rules 防火墙的规则 其实就是保存在 /etc/sysconfig/iptables
nano /etc/sysconfig/iptables
在REJECT前面加上
-A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT
保存

编辑界面.png
linux下iptables 禁止端口和开放端口
启动指令:service iptables start   
重启指令:service iptables restart   
关闭指令:service iptables stop   
然后是相关配置:/etc/sysconfig/iptables   
如何操作该配置呢?   
vim /etc/sysconfig/iptables   
然后进去修改即可,修改完了怎么办?这里很多人会想到/etc/rc.d/init.d/iptables save指令,但是一旦你这么干了你刚才的修改内容就白做了。。。   
具体方法是:   
只修改/etc/sysconfig/iptables 使其生效的办法是修改好后先service iptables restart,然后才调用/etc/rc.d/init.d/iptables save,   
因为/etc/rc.d/init.d/iptables save会在iptables服务启动时重新加载,要是在重启之前直接先调用了/etc/rc.d/init.d/iptables save那么你的/etc/sysconfig/iptables 配置就回滚到上次启动服务的配置了,这点必须注意!!!  

四、mysql基本操作

root用户使用密码登录数据库
mysql -u root -p
修改用户密码
mysqladmin -u 用户 -p password 密码
退出数据库
exit

显示所有数据库
show databases;

创建数据库
create database 数据库名;

删除数据库
drop database 数据库名;

单表查询查询所有字段
SELECT id, bookname, author, price, booktypeid FROM t_book;
SELECT * FROM t_book;

单表查询查询指定字段
SELECT bookname, author, price FROM t_book;

where条件查询
SELECT * FROM t_book t WHERE t.bookTypeId = 1;
SELECT * FROM t_book t WHERE t.price > 100;

带in关键字查询
SELECT * FROM t_book t WHERE t.bookTypeId IN (1, 3);
SELECT * FROM t_book t WHERE t.bookTypeId NOT IN (1, 3);

带between and的范围查询
SELECT * FROM t_book t WHERE t.price BETWEEN 50 AND 100;
SELECT * FROM t_book t WHERE t.price NOT BETWEEN 50 AND 100;

带like的模糊查询
/全字匹配,较少用/
SELECT * FROM t_book t WHERE t.bookName LIKE '物理学';
/单个字模糊匹配/

SELECT * FROM t_book t WHERE t.bookName LIKE '物理_';

/多个字模糊匹配/
SELECT * FROM t_book t WHERE t.bookName LIKE '物理学%';
SELECT * FROM t_book t WHERE t.bookName LIKE '%物理学%';

空值查询
SELECT * FROM t_book t WHERE t.author IS NULL;
SELECT * FROM t_book t WHERE t.author IS NOT NULL;

带and的多条件查询
SELECT * FROM t_book t WHERE (t.price NOT BETWEEN 50 AND 100) AND t.bookTypeId = 1;

带or的多条件查询
SELECT * FROM t_book t WHERE t.bookTypeId = 1 OR t.bookTypeId = 7;

distinct支重复查询
SELECT DISTINCT t.booktypeid FROM t_book t;

对查询结果排序
SELECT * FROM t_book t ORDER BY t.price;

group by分组查询
/与GROUP_CONCAT一起使用,会把结果拼接在一起/
SELECT GROUP_CONCAT(t.bookname), t.booktypeid FROM t_book t GROUP BY t.booktypeid;
/与COUNT一起使用,统计分组后每组成员的个数/
SELECT COUNT(t.bookname), t.booktypeid FROM t_book t GROUP BY t.booktypeid;
/与having一起使用,限制输出结果/
SELECT COUNT(t.bookname), t.booktypeid FROM t_book t GROUP BY t.booktypeid HAVING COUNT(t.bookname) > 3;
/WITH ROLLUP,在最后加入一个汇总行/
SELECT COUNT(t.bookname), t.booktypeid FROM t_book t GROUP BY t.booktypeid WITH ROLLUP;

limit分页查询
/查询1-5条记录/
SELECT * FROM t_book t LIMIT 0,5;
/查询6-10条记录/
SELECT * FROM t_book t LIMIT 5,5;
/查询11-15条记录/
SELECT * FROM t_book t LIMIT 10,5;

连接查询
连接查询是将两个或两个以上的表按照某个条件连接起来,从中选取需要的数据。
1、内连接查询
内连接查询是一种最常用的连接查询。内连接查询可以查询两个或者两个以上的表。
SELECT * FROM t_book, t_booktype;
SELECT * FROM t_book b, t_booktype bt WHERE b.bookTypeId = bt.id;
SELECT b.bookName, b.price, bt.bookTypeName FROM t_book b, t_booktype bt WHERE b.bookTypeId = bt.id;

2、外连接查询
外连接可以查出某一张的所有信息
a) 左连接查询
可以查询出“表1”的所有记录,而“表2”中只能查询出匹配的记录
/以左表作为全量表进行关联查询/
SELECT b.bookName, b.author, bt.bookTypeName FROM t_book b LEFT JOIN t_booktype bt ON b.bookTypeId = bt.id;
b) 右连接查询
可以查询出“表2”的所有记录,而“表1”中只能查询出匹配的记录
/以右表作为全量表进行关联查询/
SELECT b.bookName, b.author, bt.bookTypeName FROM t_book b RIGHT JOIN t_booktype bt ON b.bookTypeId = bt.id;

3、多条件连接查询
SELECT b.bookName, b.price, bt.bookTypeName FROM t_book b, t_booktype bt WHERE b.bookTypeId = bt.id AND b.price > 50;

喜欢这篇文章,就请点赞支持。喜欢我就关注我。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容