美文网首页
CentOS6安装配置python3及MySql5.1.73

CentOS6安装配置python3及MySql5.1.73

作者: hrcl2015 | 来源:发表于2018-11-09 12:00 被阅读0次

    最近租用了低配版的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;

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

    相关文章

      网友评论

          本文标题:CentOS6安装配置python3及MySql5.1.73

          本文链接:https://www.haomeiwen.com/subject/ptvnxqtx.html