linux下开启mysql远程连接的方法

1.在mysql控制台下修改权限

grant all privileges on *.* to 'root'@'%' identified by '123456' with grant option;
//root 是用户名,% 表示任意主机,'123456' 指定的登录密码(这个和本地的root密码可以设置不同,互不影响)
flush privileges; //重载系统权限
exit;//退出mysql控制台

2.CentOS环境开放3306端口

iptables -I INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT
service iptables status //查看规则是否生效

//删除规则,关闭3306端口
iptables -D INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT

注意:上面使用iptables添加/删除规则都是临时的,如果需要重启也生效,就要保存修改

service iptables save //保存规则

例外一种方式也可以实现:

vi /etc/sysconfig/iptables //在该文件中加入下面这条规则也是可以生效的
-A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT

linux下LNMP环境-4.虚拟主机配置

前几篇文章主要说了nginx以及php的安装,今天说一下配置问题,怎么在nginx里面执行php文件以及nginx网站常用配置

1.配置支持php

 cd /usr/localinx/conf
 vim  nginx.conf
     location ~ \.php$ {
        root           html;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME   $document_root$fastcgi_script_name;
        include        fastcgi_params;
  }
     #取消FastCGI server部分location的注释,并要注意fastcgi_param行的参数,改为$document_root$fastcgi_script_name,
     #或者使用绝对路径

    //测试
    cd/usr/local/nginx/html
    vim index.php 
    //内容如下
     <?php phpinfo(); ?>
    //如果能显示出php的环境信息,则表示配置成功

qq%e6%88%aa%e5%9b%be20161022183920

2.虚拟主机配置

一般情况是使用多个.conf的方法配置

打开 /usr/local/nginx/conf/nginx.conf 
在最后加入如下一行
include vhosts/vhosts.conf;
在/usr/local/nginx/conf下新建目录
mkdir vhosts
cd vhosts
vim vhosts.conf
//加入如下配置
server {
 listen 80;
 server_name testphp7.com;
 root "/usr/local/nginx/www/testphp7.com"; //你网站的目录
 location / {
 index index.html index.htm index.php;
 #autoindex on;
 }
 location ~ \.php(.*)$ {
 fastcgi_pass 127.0.0.1:9000;
 fastcgi_index index.php;
 fastcgi_split_path_info ^((?U).+\.php)(/?.+)$;
 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 fastcgi_param PATH_INFO $fastcgi_path_info;
 fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
 include fastcgi_params;
 }
}
//配置hosts文件 
vi /etc/hosts 添加 127.0.0.1 testphp7.com 
//然后配置你电脑本地hosts文件 添加testphp7.com 指向你vm中linux的ip
//我这里是
192.168.80.3  testphp7.com

重启nginx ,电脑访问testphp7.com 搞定

qq%e6%88%aa%e5%9b%be20161022191134

linux下LNMP环境-3.PHP篇(安装php7.1)

本文安装得php版本是当前最新得7.1,也是为了测试下7得性能,好了,废话不多说,开始。

首先为了安装php不失败,先预装一下mcrypt扩展,因为本人安装php7.1,好几次都提示configure: error: mcrypt.h not found. Please reinstall libmcrypt,所以防患于未然。

1.安装mcrypt

wget http://softlayer.dl.sourceforge.net/sourceforge/mcrypt/libmcrypt-2.5.8.tar.gz
tar -zxvf libmcrypt-2.5.8.tar.gz
cd /usr/local/src/libmcrypt-2.5.8
./configure --prefix=/usr/local
make
make install

安装这个不多说,老样子,记住安装位置就好,下一步会用到,/usr/local/libmcrypt

2.解压文件,执行配置

tar zxvf php-7.1.0alpha1.tar.gz
cd php-7.1.0alpha1
./configure --prefix=/usr/local/php7 \
--with-config-file-path=/usr/local/php7/etc \
--with-mcrypt=/usr/local/libmcrypt \
--with-mysql=mysqlnd \
--with-mysqli=mysqlnd \
--with-pdo-mysql=mysqlnd \
--with-gd \
--with-iconv \
--with-zlib \
--enable-xml \
--enable-bcmath \
--enable-shmop \
--enable-sysvsem \
--enable-inline-optimization \
--enable-mbregex \
--enable-fpm \
--enable-mbstring \
--enable-ftp \
--enable-gd-native-ttf \
--with-openssl \
--enable-pcntl \
--enable-sockets \
--with-xmlrpc \
--enable-zip \
--enable-soap \
--without-pear \
--with-gettext \
--enable-session \
--with-curl \
--with-jpeg-dir \
--with-freetype-dir \
--enable-opcache

注意

如果配置错误,需要安装需要的模块,直接yum一并安装依赖库,这里最好更新一下!

# yum -y install libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel mysql pcre-devel

3.编译安装

# make && make install

4.进行配置

这里配置,主要是配置php-fpm   很重要

 // 配置php-fpm
 cd /usr/local/php7/etc 
 cp php-fpm-default.conf php-fpm.conf
 //修改php-fpm.conf
 vim php-fpm.conf //将;pid = run/php-fpm.pid 前面的分号删掉
 //大约125行 去掉include=/usr/local/php7/etc/php-fpm.d/*.conf前面的分号
 //创建www.conf配置
 cd /usr/local/php7/etc/php-fpm.d
 cp www.conf.default www.conf
 //创建php.ini
 cp /usr/local/src/php-7.1.0alpha1/php.ini-production /usr/local/php7/etc/php.ini
 //设置php-fpm开机启动
 cp /usr/local/src/php-7.1.0alpha1/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
 //设置权限并启动php-fpm:
 chmod 755 /etc/init.d/php-fpm
 /etc/init.d/php-fpm start
 chkconfig php-fpm on
 //最后,给出php-fpm以服务的方式启动、停止和重启:
 service php-fpm start
 service php-fpm stop
 service php-fpm reload

qq%e6%88%aa%e5%9b%be20161022024032

 

 

 

 

 

qq%e6%88%aa%e5%9b%be20161022025912

 

 

 

这个时候 基本大功告成了,如果大家有什么错误,可自行网上找找,一般启动不了,都是配置得错误,仔细看看我上面的配置流程

下篇文章介绍php结合nginx的虚拟主机配置

 

linux下LNMP环境-2.Nginx篇

1、下载nginx(stable版本)

[root@centos /]# cd /usr/local/src
[root@centos src]# wget -P /tmp http://nginx.org/download/nginx-1.8.1.tar.gz

或者你可以提前下载好放到指定位置

2、解压nginx

[root@centos src]# tar xf nginx-1.8.1.tar.gz 
[root@centos src]# cd nginx-1.8.1
[root@centos nginx-1.8.1]# ./configure --help(查看参数)

3、编译nginx

如果指定用户和用户组,需要先创建

//创建用户www和用户组www
# groupadd www
# useradd -g www www

如果不需要指定,可不必创建,下面这个命令也不必配置–user=www –group=www

./configure --prefix=/usr/local/nginx --sbin-path=/usr/sbin/nginx --user=www --group=www --with-http_ssl_module --with-http_gzip_static_module

说明:

./configure是源代码安装的第一步,主要的作用是对即将安装的软件进行配置,检查当前的环境是否满足要安装软件的依赖关系,但并不是所有的tar包都是源代码的包,可以ls看看有没有configure这个文件,也许你下的是二进制的包,如果是二进制的包,解压后直接就能使用

–prefix  //安装位置

–sbin-path //可执行文件安装位置

–with指的是安装本文件所依赖的库文件

接着执行 编译(make)、安装(make install)

make && make install

最后启动nginx

nginx //启动
nginx -s stop// 停止
nginx -s reload // 重新加载

测试:

浏览器访问:http://localhost如能出现nginx页面则表示成功  如果你配置了其他IP 则访问ip地址即可。

qq%e6%88%aa%e5%9b%be20161021001555

 

 

 

 

 

 

 

最后说一下,配置启动nginx得方式有多种,这里说明一下

    //启动nginx

    **第一种方式 指定--sbin-path=/usr/sbin/nginx**
    nginx //启动
    nginx -s stop// 停止
    nginx -s reload // 重新加载

    **第二种方式 不指定--sbin-path**
    cd /usr/local/nginx
    ./sbin/nginx
    重启nginx  /usr/local/nginx/sbin/nginx -s reload

    **第三种方式**
     配置开机启动
    首先写一个shell脚本,脚本名称:nginx
    vi /etc/rc.d/init.d/nginx

    #! /bin/bash
    # chkconfig: 35 85 15  
    # description: Nginx is an HTTP(S) server, HTTP(S) reverse
    set -e
    PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
    DESC="nginx daemon"
    NAME=nginx
    DAEMON=/usr/local/nginx/sbin/$NAME (这里是nginx安装是 --sbin-path指定的路径)
    SCRIPTNAME=/etc/init.d/$NAME
    test -x $DAEMON || exit 0
    d_start(){
        $DAEMON || echo -n " already running"
    }
    d_stop() {
        $DAEMON -s quit || echo -n " not running"
    }
    d_reload() {
        $DAEMON -s reload || echo -n " counld not reload"
    }
    case "$1" in
    start)
        echo -n "Starting $DESC:$NAME"
        d_start
        echo "."
    ;;
    stop)
        echo -n "Stopping $DESC:$NAME"
        d_stop
        echo "."
    ;;
    reload)
        echo -n "Reloading $DESC configuration..."
        d_reload
        echo "reloaded."
    ;;
    restart)
        echo -n "Restarting $DESC: $NAME"
        d_stop
        sleep 2
        d_start
        echo "."
    ;;
    *)
        echo "Usage: $SCRIPTNAME {start|stop|restart|reload}" >&2
        exit 3
    ;;
    esac
    exit 0

    //将shell脚本放入到 /etc/rc.d/init.d/中,并执行下列命令

    chmod +x /etc/rc.d/init.d/nginx (设置可执行权限)
    chkconfig --add nginx (添加系统服务)

    service nginx start
    service nginx stop
    service nginx restart
    service nginx reload

    浏览器访问:http://localhost如能出现nginx页面则表示成功

    // 查看nginx进程
    ps -ef | grep nginx
    // 查看进程个数 去掉首位的
    ps -ef | grep nginx | wc -l

    // 查看80端口
    netstat -anpt

 

linux下LNMP环境-1.准备篇(源码编译安装)

由于安装过程有点多,所以这里分开来写,这里采用的是Centos6.5来做的教程。

准备工作,安装依赖库

几点说明:

gcc是用来编译c源码得,源码安装必须安装gcc

pcre、openssl、zlib是安装nginx时需要的,因为Nginx需要其他第三方库的支持,比如rewrite模块需要pcre库

cmake是安装MySQL时需要的

这里安装这些依赖库是直接采用yum源进行安装得,方便快捷。

下面几个教程中,大家所用到得源码包都可以到指定官网进行下载,然后统一上传到linux,方便进行安装

nginx: http://nginx.org

php:http://cn2.php.net

mysql:http://dev.mysql.com

cmake:http://www.cmake.org

这里是我统一下载好得,上传到/usr/local/src目录

qq%e6%88%aa%e5%9b%be20161021231758

 

 

 

 

 

yum命令:

yum -y install gcc automake autoconf libtool make gcc-c++ glibc libxslt-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5-devel libidn libidn-devel openssl openssl-devel pcre pcre-devel libmcrypt libmcrypt-devel cmake

下面是安装成功截图:

qq%e6%88%aa%e5%9b%be20161020225618

 

 

 

 

 

 

 

由于这一篇是准备工作,所以直接采用了yum安装,有兴趣的同学,也可以自行查找怎么手动安装依赖库

下一篇,开始进行nginx的安装

JS声明全局变量的三种方式详解

声明方式一:

使用var(关键字)+变量名(标识符)的方式在function外部声明,即为全局变量,否则在function声明的是局部变量。该方式即为显式声明详细如下:

var test = 5;  //全局变量
function a()
{
  var cc=3; //局部变量
  alert(test);
}
function b(){alert(test);}

声明方式二:
没有使用var,直接给标识符test赋值,这样会隐式的声明了全局变量test。即使该语句是在一个function内,当该function被执行后test变成了全局变量。

test = 5;//全局变量 
function a()
{
  aa=3; //全局变量
  alert(test);
}

声明方式三:
使用window全局对象来声明,全局对象的属性对应也是全局变量,详细如下:

window.test;
window.test = 5;

全局变量的优点:
可以减少变量的个数,减少由于实际参数和形式参数的数据传递带来的时间消耗。

全局变量的缺点:
(1)全局变量保存在静态存贮区,程序开始运行时为其分配内存,程序结束释放该内存。与局部变量的动态分配、动态释放相比,生存期比较长,因此过多的全局变量会占用较多的内存单元。

(2)全局变量破坏了函数的封装性能。函数象一个黑匣子,一般是通过函数参数和返回值进行输入输出,函数内部实现相对独立。但函数中如果使用了全局变量,那么函数体内的语句就可以绕过函数参数和返回值进行存取,这种情况破坏了函数的独立性,使函数对全局变量产生依赖。同时,也降低了该函数的可移植性。

(3)全局变量使函数的代码可读性降低。由于多个函数都可能使用全局变量,函数执行时全局变量的值可能随时发生变化,对于程序的查错和调试都非常不利。
因此,如果不是万不得已,最好不要使用全局变量。

linux centos永久设置IP地址的方法

上篇文章说道,通过命令 ifconfig eth0 设置IP地址后,这个设置只是存在于内存中的,重启之后就会失效,本文主要说一下怎么样的永久设置,大体有俩种办法:

1.通过setup图形界面进行设置,更加直观化

qq%e6%88%aa%e5%9b%be20161016193131

 

 

 

 

 

 

 

 

 

这个方法不多介绍,网上示例也多。

2.通过修改配置文件达到设置IP的目的

输入命令

#vi /etc/sysconfig/network-scripts/ifcfg-eth0

开始编辑网卡的配置文件。

1
2
3
4
5
6
7
8
9
10
DEVICE=eth0   #设备名
BOOTPROTO=static #开机协议  
                    static(静态IP)
                    none(不指定,设置固定ip的情况,这个也行,但是如果要设定多网口绑定bond的时候,必须设成none)
                    dhcp(动态获得IP相关信息)
ONBOOT=yes       #启动或者重启网络时,是否启动该设备,yes是启动,no是不启动
IPADDR=192.168.126.0 #IP地址
NETMASK=255.255.255.0  #子网掩码
GATEWAY=222.222.222.222 #默认网关
TYPE=Ethernet    #类型 以太网

上述俩种方法修改完成后都需要重启下网络服务

#servicenetwork restart

OK 这个时候就已经设置OK了,输入ifconfig查询一下:

qq%e6%88%aa%e5%9b%be20161016194754

 

 

 

 

 

 

 

 

 

 

说明:本文设置IP都是为了本地连接虚拟机测试而用,大家具体情况具体设置。

使用Xshell远程连接本地VM虚拟机Linux

本文使用的是VMware10(这里简称VM)和Centos6进行本地连接测试的

注意:这里安装VM和装linux系统的过程就不介绍了

1.打开VM虚拟网络编辑器,看到如下设置
qq%e6%88%aa%e5%9b%be20161014132736

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

这里我们使用的是主机连接,所以观察到他的IP地址是192.168.50.0

对了注意一点是centos网络连接选择的是仅主机模式。

qq%e6%88%aa%e5%9b%be20161014133015

 

 

 

 

 

 

 

 

 

 

2.到linux中设置IP地址  刚刚所看到的IP:192.168.50.0

qq%e6%88%aa%e5%9b%be20161014133413

 

 

 

 

 

 

注意:这里只是临时设置了一下 ,重启后IP配置会失效

这个时候你只需要在你window中测试一下  这个IP是否可以拼得通,如果ping得通,基本就没有什么问题了,

qq%e6%88%aa%e5%9b%be20161014133605

 

 

 

 

 

 

 

 

 

 

说到最后,需要大家注意的是,如果你window中可以ping得通这个IP,而到了远程工具中却连接不上,可以看看你的linux是否关闭防火墙以及开启ssh

具体大家查下命令,我这里就不做过多解释了。