最近租用了低配版的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
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
保存
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;
喜欢这篇文章,就请点赞支持。喜欢我就关注我。