linux和window文件共享 安装samba

对于个人来说,我一般开发环境用linux,好处就是,本地测试没有问题,线上也不会出什么问题。

使用samba,可以把局域网的linux和window共享,通过映射网络盘的方式可以挂在到windows文件系统下面,使用起来和本地磁盘没有区别,下面介绍,如何安装samba。

  1. 安装samba
    yum install samba samba-client samba-swat

    2.启动

  2. /etc/init.d/smb start

    3.查看samba的服务启动情况

    service smb status

    4.开机启动

    chkconfig --level 35 smb on

    5.添加账户

    smbpasswd -a root

    输入密码

    6.关闭防火墙:

    service iptables stop

    7
    编辑配置文件:/etc/samba/smb.conf

    [public]  
    comment = Public Stuff  
    path = /www  
    public = yes  
    writable = yes  
    printable = no

    8.重启samba

    service smb restart

    9
    权限问题:需要设置selinux

    setenforce 0

     

 

10 上面是之前配置samba的步骤,下面为补充
首先需要开放端口,iptables,如果是本地,那么直接关掉iptables,免得麻烦
譬如我想配置public下的需要用户名和密码访问,那么
vim /etc/samba/smb.conf

 

  1. [public]    
        comment = Public Stuff    
        path = /www/web/develop/erp    
        public = yes    
        writable = yes    
        printable = no  
        valid users = myerp    
    ;  password: myerp123  
    [ts]  
        comment = TS  
        path = /www/web/develop/e_commerce_huang_di  
        valid users = @ts

    public部分,添加的是myerp的用户名

    需要执行,一定不要忘记参数 -a

    useradd myerp  
      
    smbpasswd -a myerp

     

    [root@grande erp]# smbpasswd -a myerp  
    New SMB password:  
    Retype new SMB password:  
    [root@grande erp]# service smb restart

     

    #然后重启smb
    service smb restart

    这样,在linux就配置好了,只有liming用户才能访问

    在windows下面打开我的电脑,然后点击 映射网络驱动器

    在弹出的框内填写内部ip地址,后面一定要加上public部分。不然后无法访问

    登陆时重新连接,使用其他凭证连接勾选,然后点击完成

    点击后出现框,输入密码即可。

    保存后,在我的电脑就会出现一个磁盘,直接点击访问即可。

    1. service smb restart

       

      备注,如果一个文件夹下面有很多系统,而且,想要某个用户只能看到2-3个系统

      那么,可以在samba中配置几个块,譬如:

      vim /etc/samba/smb.conf

       

      [erp]  
        
      path = /www/web/develop/erp  
        
      valid users = sambauser myerpdevelop  
        
      [intosmile]  
        
      path = /www/web/develop/intosmile  
      valid users = sambauser myerpdevelop  
        
        
      [wordpress]  
        
      path = /www/web/develop/wordpress  
      valid users = sambauser myerpdevelop

       

      这样样sambauser 和myerpdevelop 两个用户都可以访问 /www/web/develop目录下面的三个文件夹   erp  intosmile  wordpress

      其他则看不到

      在网络映射文件中依次添加

       

      \\10.10.10.252\wordpress  
        
      \\10.10.10.252\erp  
        
      \\10.10.10.252\intosmile

      在映射文件磁盘中一个ip只能使用一个用户名,如果使用另外一个用户名,需要把这个用户对应的网络映射磁盘断掉。

       

YII2开发环境文件上传 – 安装vsftpd

vsftpd是一款在Linux发行版中最受推崇的FTP服务器程序。特点是小巧轻快,安全易用。

在用YII2框架开发系统的时候,有时候有一些图片等非版本控制的东西,我们需要上传文件,那么我们可以用vsftpd。

yum install vsftpd

设置开机启动vsftpd

chkconfig vsftpd on

启动vsftpd:

service vsftpd start

开发端口:

/sbin/iptables -I INPUT -p tcp --dport 21 -j ACCEPT 
/sbin/iptables -I INPUT -p tcp --dport 22 -j ACCEPT

 

/etc/rc.d/init.d/iptables save
service iptables restart

配置ftp账户:

vi /etc/vsftpd/vsftpd.conf

 

如果我想给/www/web目录添加ftp,那么:

下面是添加ftpuser用户,设置根目录为/home/wwwroot/ftpuser,禁止此用户登录SSH的权限,并限制其访问其它目录。

1、修改/etc/vsftpd/vsftpd.conf

将底下三行

#chroot_list_enable=YES

# (default follows)

#chroot_list_file=/etc/vsftpd.chroot_list

改为

chroot_list_enable=YES  
# (default follows)  
chroot_list_file=/etc/vsftpd/chroot_list

禁止允许匿名用户登陆,YES是,NO否

anonymous_enable=NO

3、增加用户ftpuser,指向目录/home/wwwroot/ftpuser,禁止登录SSH权限

useradd -d /www/web -g ftp -s /sbin/nologin ftpusername  
  
passwd ftpusername

然后设置密码,完成后就设置成功一个账户

4、编辑文件chroot_list:

vi /etc/vsftpd/chroot_list

ftpusername

将刚才新建的账户添加上,多个账户用回车隔开,也就是说,上面新建一个不能登录的系统账户,指向了/www/web目录

然后我们在这个文件里面把这个账户添加上就OK了

5、重新启动vsftpd

service vsftpd restart

 

YII2开发环境版本控制 – 安装SVN

在开发的过程中,我们需要使用 svn进行版本控制。

1.

yum install subversion

 

svnserve --version

查看具体的版本信息,如果有结果,则代表SVN安装成功。

2. 创建路径:

/home/svn/repo
#创建仓库
svnadmin create /home/svn/repo

3.进行配置:

vim /home/svn/repo/conf/svnserve.conf

 

[general]  
anon-access = none  //匿名访问的权限,设置为none表示为不允许,默认是read  
auth-access = write //可以是read,write,none,默认是write  
password-db = passwd //密码数据库的路径,去掉前面的#  
authz-db = authz

4.配置svn的密码文件:

vim  /home/svn/repo/conf/passwd 
[user]  
username = passwd

上面的例子为填写用户名和密码,如果是water 密码为888888

[user]  
water = 888888  

配置文件 /home/svn/repo/conf/authz

[groups]  
[/]  
terry = rw  
#代表terry 这个账户对应的路径为根目录,对根目录下的所有文件和文件夹有读写的权限  
[/magento]  
terry = r  
#代表terry这个账户对应的路径是magento文件夹,在这个目录下的文件只有读的权限  
[/magento/app/etc/local.xml]  
terry =   
#代表terry对上面这个文件不可见。即:不可读,不可写

设置可读

vim  /home/svn/repo/conf/svnserve.conf  
anon-access = none

设置完成后,关闭svn,重启

  
关闭svn:   killall svnserve  
启动svn:  svnserve -d -r /home/svn/repo --listen-host  ip地址

开放端口:

/sbin/iptables -I INPUT -p tcp --dport 3690 -j ACCEPT
/etc/rc.d/init.d/iptables save

 

 

经过了4步骤,我们创建了账户,设置了账户的权限,当我们用svn工具访问svn://ip地址,就可以访问了。

在本地可以通过上传文件到svn服务器

我们想要的是svn中提交的文件,复制到服务器的web路径中,所以我们需要把svn中的数据提交到web路径

这里我们使用的命令式svn up,强制提交:svn up –force

首先我们需要先设置,把svn中的路径,对应的web目录

譬如:svn://192.168.1.12/magento 对应到/www/web/come/public_html,我们的配置为

svn co svn://192.168.1.12/magento  /www/web/come/public_html

 

然后需要输入root密码,
然后需要输入提交账户,这个账户就是svn的在上面配置文件中添加的账户,
更改svn up 账户命令:svn co --username xxx svn://192.168.1.12/magento

 

6

如果svn up 报错:

Skipped ‘.’

需要到输出的路径下,譬如到/www/web/come/public_html下面svn up 就可以了

7

开机启动svn

vi /etc/rc.local  
在最后一行加入:  
svnserve -d -r /home/svn/repo

 

8

自动更新,不需要svn up

svn co svn://115.29.18.29/erp  /www/web/

在SVN 项目版本库的存储目录下的hooks 目录,新建立一个post-commit文件:

 

vi /home/svn/repo/hooks/post-commit

 

touch /home/svn/repo/hooks/svn_hook.log  
chmod 777 -R /home/svn/repo/hooks/svn_hook.log  


#!/bin/sh  
REPOS="$1"  
REV="$2"  
WEB=/www/web  
export LANG=en_US.UTF-8  
echo `whoami`,$REPOS,$REV >> /home/svn/repo/hooks/svn_hook.log  
svn update $WEB

保存,退出。
权限:chmod 777 post-commit

测试,看脚本是否有权限问题:

复制代码 代码示例:

./post-commit

以后每次客户端提交操作,就会自动运行该脚本。

 

 

 

Yii2 – Mongodb的安装和配置 mongo

mongodb官方安装文档:https://www.mongodb.com/download-center

下面是centos环境安装mongodb3.2的步骤

1.

sudo rpm --import https://www.mongodb.org/static/pgp/server-3.2.asc
touch /etc/yum.repos.d/mongodb-org-3.2.repo
vim /etc/yum.repos.d/mongodb-org-3.2.repo  
添加内容如下:  
[mongodb-org-3.2]  
name=MongoDB Repository  
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.2/x86_64/  
gpgcheck=1  
enabled=1

 

sudo yum install -y mongodb-org

2. vim /etc/selinux/config

SELINUX=disabled

3. mongodb 安装完成,可以启动mongodb了

sudo service mongod start

当然,我上面配置的是一个简单的mongodb,没有配置复制集和分片

安全ip连接设置:vim /etc/mongod.conf

net:
  port: 27017
  bindIp: 127.0.0.1

port代表开放的访问端口,bindIp这个是一个安全ip配置,允许那些ip连接mongodb,如果设置成bind_ip = 0.0.0.0,代表任意ip,建议只写连接的ip,如果是本机,就填写127.0.0.1即可。

这个是一个安全设置,线上系统一定要注意,iptables设置,只允许部分ip访问该端口,其他的pass掉,而且mongodb也要设置。

另外,对于线上系统,最好是使用账号密码的方式连接,进一步增强安全性。

 

4.安装mongodb的php扩展 ext-mongodb

注意:Fecshop 支持php7,需要安装ext-mongodb扩展,注意,这是两个扩展,ext-mongo扩展只能在php5中使用, ext-mongodb可以在php5和php7中使用,php7不能使用ext-mongo扩展。

 

4.1安装php的ext-mongodb扩展(兼容php7,fecshop需要安装ext-mongodb扩展,而不是ext-mongo扩展,ext-mongo只能在php5中使用,ext-mongodb可以在php5,php7,VVMH中使用,这里只安装ext-mongodb扩展

https://pecl.php.net/package/mongodb下载mongodb的安装包,我的安装步骤如下:

wget https://pecl.php.net/get/mongodb-1.2.5.tgz
tar zxvf mongodb-1.2.5.tgz
cd mongodb-1.2.5
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make && make install

*php.ini中加入:

extension=mongodb.so

 

重启php

对于mongodb的GUI,不要使用rockmongo了,现在有更好的工具:

你可以使用 RoboMongo GUI工具连接mongodb,下载地址 , 因为mongodb默认设置无密码,只允许127.0.0.1登录, 因此,可以使用RoboMongo的ssh方式登录,填写您的主机的ssh信息即可登录。(robomongo支持很多方式连接mongodb)

5.安装yii2-mongodb的扩展(如果您在安装fecshop,下面的步骤不需要操作)

插件地址:https://github.com/yiisoft/yii2-mongodb

在yii2的根目录下面运行:(已经安装composer)

composer require --prefer-dist yiisoft/yii2-mongodb

完成后,mongodb的yii2扩展安装完成

6.配置

'mongodb' => [
            'class' => 'yii\mongodb\Connection',
      //'class' => 'backend\models\core\mongodb\Mconnection',
      # 有账户的配置
            //'dsn' => 'mongodb://demofancyecommerce:fdaVBDFS#fdfdtyg423DF23#$@localhost:27017/demofancyecommerce',
      # 无账户的配置
      'dsn' => 'mongodb://127.0.0.1:27017/market',
      //'dsn' => 'mongodb://10.10.10.252:10001/erp,mongodb://10.10.10.252:10002/erp,mongodb://10.10.10.252:10004/erp?replicaSet=terry&readPreference=primaryPreferred',
      
        ],

然后就可以在yii2中使用mongodb了

yii2 – redis 配置

  1. 安装redis, 下面是2.8,注意,redis版本一定要高,2.2.7一下的版本是不行的,不支持php-redis,建议安装2.8+的版本
wget http://download.redis.io/releases/redis-3.2.9.tar.gz  
tar xzf redis-3.2.9.tar.gz  
cd redis-3.2.9  
make

2.6.14 这个版本有点老,大家可去找新的redis下载

cd src  
cp redis-server /usr/local/bin/  
cp redis-cli /usr/local/bin/

 

mkdir /etc/redis  
mkdir /var/redis  
mkdir /var/redis/6379

 

cd ..  
cp utils/redis_init_script /etc/init.d/redis_6379  
cp redis.conf /etc/redis/6379.conf

 

/etc/init.d/redis_6379 start

vim /etc/redis/6379.conf ,找到如下的代码部分,修改

daemonize to yes  
pidfile to /var/run/redis_6379.pid  
logfile to /var/log/redis_6379.log  
dir to /var/redis/6379  
maxmemory 268435456

maxmemory 这里设置的是256mb,您可以按照您的配置自己设置。

设置开机启动:vim /etc/rc.d/rc.local,添加下面的代码

/etc/init.d/redis_6379 start

1.2 (可选操作)对于redis的磁盘存储

redis有几种内存的数据同步到磁盘的操作,详细可以参看文章:https://www.cnblogs.com/datang6777/p/7056272.html

我们选择的是:Append-only file, vim /etc/redis/6379.conf

appendonly yes      #启用aof持久化方式

appendfsync everysec     #每秒钟强制写入磁盘一次,在性能和持久化方面做了很好的折中,推荐

auto-aof-rewrite-percentage 200   #自动的bgrewriteaof,aof文件的大小超过基准百分之多少后触发bgrewriteaof。默认这个值设置为100,意味着当前aof是基准大小的两倍的时候触发bgrewriteaof。把它设置为0可以禁用自动触发的功能。
auto-aof-rewrite-min-size 128mb     #当前aof文件大于多少字节后才触发。避免在aof较小的时候无谓行为。默认大小为64mb。

#  然后就是触发检查的主逻辑,serverCron时间事件中每次都会检查现有状态和参数来判断是否需要启动bgrewriteaof。
#  如果aof文件增长百分率growth大于auto_aofrewrite_perc,则自动的触发后一个bgrewriteaof。

保存,重启redis

/etc/init.d/redis_6379 stop
/etc/init.d/redis_6379 start

 

2.安装redis的扩展。

yum install git
git clone git://github.com/owlient/phpredis
cd phpredis
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make && make install

如果上述出现报错,可以尝试用另外一个源:

git clone git://github.com/nicolasff/phpredis

php.ini中添加:

extension=redis.so

 

3.yii2 redis扩展的安装,以及配置:

在配置好的yii2根目录下面执行(您已经安装了composer)

composer require --prefer-dist yiisoft/yii2-redis

等待片刻就可以安装好yii2 的 redis 扩展

 

4.yii2中redis的配置

首先基于安全考虑,我们需要给redis设置密码,除非,您的redis端口关闭。

vim /etc/redis/6379.conf

找到行,把前面#去掉,后面加redis的密码

requirepass  rds423fsadD

重启redis就可以了。

/etc/init.d/redis_6379 stop  
/etc/init.d/redis_6379 start

这样redis密码验证就有了。

yii2的配置如下:

'redis' => [
            'class' => 'yii\redis\Connection',
            'hostname' => '127.0.0.1',
            'port' => 6379,
            'database' => 1,
      //'unixSocket' => '/var/run/redis/redis.sock',
      'password'  => 'rds423fsadD',
      // 'unixsocket' => '/var/run/redis/redis.sock',
    //	'unixSocket' => '/tmp/redis.sock',
        ],

重启redis , 这里  yii2就配置好redis了

5.redis的使用:刷新缓存:

[root@E3-1230v2-829 catalog]# redis-cli  
127.0.0.1:6379> auth rds!23v3cv3#ds  
OK  
127.0.0.1:6379> flushall  
OK  
127.0.0.1:6379>

redis-cli flushall  会报错(需要按照上面的步骤登录)

 

6.带有密码的redis,定时脚本清空缓存:

新建/www/script/redis_reflush_all.sh,添加如下内容

/usr/local/bin/redis-cli -a 'rds!2016!FDR' flushall

添加到cron中,   crontab -e,添加如下内容,保存

30 18 * * *  /bin/bash  /www/web/intosmile.com/shell/flushall.sh

就会定时清空redis的内容了

 

7. yii2中配置session 和 cache 使用redis

<?php
return [
    'components' => [
       
    'session' => [
      //'class' => 'yii\mongodb\Session',
      'class' => 'yii\redis\Session',
      //'db' => 'mongodb',
      //'sessionCollection' => 'session',
      'timeout' => 6000,
    ],
    
    'cache' => [
            'class' => 'yii\redis\Cache',
      //'class' => 'yii\caching\FileCache',  
      'keyPrefix' => 'rediscache-##$fdas5ygjD',
        ],

这样cache 就可以使用redis 了。

Linux php 扩展安装 mongo ,redis ,soap,imap,pdo_mysql,oauth

  1. 安装mongodb 参看文章:

Yii2 – Mongodb的安装和配置 mongo

2.安装redis

yum install git
git clone git://github.com/owlient/phpredis  
cd phpredis 
/usr/local/php/bin/phpize  
./configure --with-php-config=/usr/local/php/bin/php-config  
make && make install

如果上述出现报错,可以尝试用另外一个源:

git clone git://github.com/nicolasff/phpredis

php.ini中添加:

extension=redis.so

3.安装php  soap扩展

cd php-5.4.34/ext/soap
/usr/local/php/bin/phpize 
./configure -with-php-config=/usr/local/php/bin/php-config -enable-soap
make  
make install

php.ini加入:

extension=soap.so

4.安装imap

yum -y install krb5-devel libc-client libc-client-devel   
ln -sv /usr/lib64/libc-client.so /usr/lib/libc-client.so  
cd php-5.4.34/ext/imap  
/usr/local/php/bin/phpize  
./configure --with-php-config=/usr/local/php/bin/php-config --with-imap=/usr/lib64 --with-imap-ssl --with-kerberos  
make && make install  
vim /etc/php.ini  
extension=imap.so

5.安装 linux  php pdo_mysql 扩展

ln -s /usr/local/mysql/include/* /usr/local/include/  
wget http://pecl.php.net/get/PDO_MYSQL-1.0.2.tgz  
tar zxvf PDO_MYSQL-1.0.2.tgz  
cd PDO_MYSQL-1.0.2  
/usr/local/php/bin/phpize  
./configure -with-php-config=/usr/local/php/bin/php-config -with-pdo-mysql=/usr/local/mysql -with-mysql=/usr/local/mysql/  
  
make  
make install
extension=pdo_mysql.so

6.安装oauth扩展

wget http://pecl.php.net/get/oauth-1.1.0.tgz  
tar -zxf oauth-1.1.0.tgz && cd oauth-1.1.0  
/usr/local/php/bin/phpize  
./configure --with-php-config=/usr/local/php/bin/php-config  
make&&make install  
vim /etc/php.ini  
添加  
extension=oauth.so

OK,完毕完成。

Linux – 安装nginx – 搭配YII2环境

我们在开发和测试环境,需要为yii2搭配环境,这里说的是安装nginx

1.安装脚本:

wget nginx.org/download/nginx-1.11.13.tar.gz  
tar zxvf nginx-1.11.13.tar.gz  
cd nginx-1.11.13  
./configure --with-http_ssl_module  --with-http_v2_module
make && make install

 

【 题外话:

–with-http_v2_module 配置代表开启http2模块,您可以通过下面的方式设置http2

listen 443 ssl http2;

可以通过下面的链接找到工具测试是否开启http2:https://www.kejianet.cn/open-http2/

题外话:】

2.启动脚本:

touch /etc/init.d/nginx
vim /etc/init.d/nginx

加入代码,wq保存

#!/bin/bash  
# nginx Startup script for the Nginx HTTP Server  
# it is v.0.0.2 version.  
# chkconfig: - 85 15  
# description: Nginx is a high-performance web and proxy server.  
#              It has a lot of features, but it's not for everyone.  
# processname: nginx  
# pidfile: /var/run/nginx.pid  
# config: /usr/local/nginx/conf/nginx.conf  
nginxd=/usr/local/nginx/sbin/nginx  
nginx_config=/usr/local/nginx/conf/nginx.conf  
nginx_pid=/var/run/nginx.pid  
RETVAL=0  
prog="nginx"  
# Source function library.  
. /etc/rc.d/init.d/functions  
# Source networking configuration.  
. /etc/sysconfig/network  
# Check that networking is up.  
[ ${NETWORKING} = "no" ] && exit 0  
[ -x $nginxd ] || exit 0  
# Start nginx daemons functions.  
start() {  
if [ -e $nginx_pid ];then  
   echo "nginx already running...."  
   exit 1  
fi  
   echo -n $"Starting $prog: "  
   daemon $nginxd -c ${nginx_config}  
   RETVAL=$?  
   echo  
   [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx  
   return $RETVAL  
}  
# Stop nginx daemons functions.  
stop() {  
        echo -n $"Stopping $prog: "  
        killproc $nginxd  
        RETVAL=$?  
        echo  
        [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /var/run/nginx.pid  
}  
# reload nginx service functions.  
reload() {  
    echo -n $"Reloading $prog: "  
    #kill -HUP `cat ${nginx_pid}`  
    killproc $nginxd -HUP  
    RETVAL=$?  
    echo  
}  
# See how we were called.  
case "$1" in  
start)  
        start  
        ;;  
stop)  
        stop  
        ;;  
reload)  
        reload  
        ;;  
restart)  
        stop  
        start  
        ;;  
status)  
        status $prog  
        RETVAL=$?  
        ;;  
*)  
        echo $"Usage: $prog {start|stop|restart|reload|status|help}"  
        exit 1  
esac  
exit $RETVAL  

3.添加自启动

vim /etc/rc.d/rc.local
添加:
/etc/init.d/nginx start

添加nginx用户:

groupadd nginx  
useradd -g nginx nginx

 

然后设置权限:

chmod 755 /etc/init.d/nginx

4.启动nginx

/etc/init.d/nginx start

到这里就启动完成ngxin,我们需要配置nginx

5.配置nginx

添加文件地址/www/web

mkdir -p /www/web

添加log文件:

mkdir /var/log/nginx  
touch /var/log/nginx/error.log  
chmod 777 -R /var/log/nginx/error.log

添加nginx 文件access.log和error.log

mkdir /www/web_logs  
touch /www/web_logs/access.log  
chmod 777 /www/web_logs/access.log  
touch /www/web_logs/error.log  
chmod 777 /www/web_logs/error.log

nginx的配置如下:

/usr/local/nginx/conf/nginx.conf,代码如下:

user  nginx nginx;
worker_processes  4;

error_log  /var/log/nginx/error.log warn;
pid        /usr/local/nginx/logs/nginx.pid;
worker_rlimit_nofile 65535;

events {
    use epoll;
    worker_connections  65535;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    server_names_hash_bucket_size 128;
    client_header_buffer_size 32k;
    large_client_header_buffers 4 32k;
    client_max_body_size 8m;
#    limit_conn_zone $binary_remote_addr zone=one:32k;

    sendfile        on;
    tcp_nopush     on;
  

    keepalive_timeout  120;
    tcp_nodelay on;
   
    fastcgi_buffers 8 128k;
    fastcgi_connect_timeout 9900s;
    fastcgi_send_timeout 9900s;
    fastcgi_read_timeout 9900s;

    gzip  on;
    gzip_min_length  1k;
    gzip_buffers     4 16k;
    gzip_http_version 1.1;
    gzip_comp_level 2;
    gzip_types       text/plain application/x-javascript text/css application/xml;
    gzip_vary on;

    log_format  wwwlogs  '$remote_addr - $remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for';
    
    include conf.d/*.conf;
}

/usr/local/nginx/conf/none.conf,代码如下:

location / {
        index index.html index.php; ## Allow a static html file to be shown first
        try_files $uri $uri/ @handler; ## If missing pass the URI to Magento's front handler
        expires 30d; ## Assume all files are cachable
#		rewrite ^/$ /index.php last;
#        rewrite ^/(?!index\.php|robots\.txt|static)(.*)$ /index.php/$1 last;
    }

    ## These locations would be hidden by .htaccess normally
    location /app/                { deny all; }
    location /includes/           { deny all; }
    location /lib/                { deny all; }
    location /media/downloadable/ { deny all; }
    location /pkginfo/            { deny all; }
    location /report/config.xml   { deny all; }
    location /var/                { deny all; }
    location /var/email/ {allow all;}
    location /var/export/ { ## Allow admins only to view export folder
        auth_basic           "Restricted"; ## Message shown in login window
        auth_basic_user_file htpasswd; ## See /etc/nginx/htpassword
        autoindex            on;
    }
      location  /. { ## Disable .htaccess and other hidden files
        return 404;
    }

    location @handler { ## Magento uses a common front handler
        rewrite / /index.php;
    }

    location ~ .php/ { ## Forward paths like /js/index.php/x.js to relevant handler
        rewrite ^(.*.php)/ $1 last;
    }

 

/usr/local/nginx/conf/conf.d/default.conf  这个文件是网站内容的配置。譬如如下:

server {
    listen       1000;
    listen 443 ssl;
    
    server_name 192.168.220.100;
    root  /www/web/datacenter/datacenter_1000/appadmin/web;
    server_tokens off;
        include none.conf;
        index index.php;
        access_log /www/web_logs/access.log wwwlogs;
        error_log  /www/web_logs/error.log  notice;
        location ~ \.php$ {
                fastcgi_pass   127.0.0.1:9000;
                fastcgi_index  index.php;
                include fcgi.conf;
        }

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
                expires      30d;
        }

        location ~ .*\.(js|css)?$ {
                expires      12h;
        }
        
    location ~ /.svn/ {
                deny all;
        }

}

上面的意思为:

listen 代表监听的端口,线上都是填写80,80是默认端口,我们访问的网站,默认都是80端口

server_name  填写对应的IP,或者域名

root 代表上面访问IP或者域名,网站的根目录

填写完成上面的后,保存,退出。重启nginx

/etc/init.d/nginx restart

6.新建文件:

mkdir -p  /www/web/datacenter/datacenter_1000/appadmin/web
touch  /www/web/datacenter/datacenter_1000/appadmin/web/index.php
vim /www/web/datacenter/datacenter_1000/appadmin/web/index.php

添加代码

<?php
echo phpinfo();
?>

访问配置的nginx的域名或者IP就可以看到页面了。

7. nginx  php 隐藏版本号

vi /usr/local/nginx/conf/nginx.conf
#在http{}中加入
server_tokens off;

 

第二歩:

 

vi /usr/local/nginx/conf/fastcgi_params
#将里面的
#fastcgi_param SERVER_SOFTWARE nginx/$nginx_version;
#修改为:
fastcgi_param SERVER_SOFTWARE nginx;

 

 

隐藏PHP版本号

 

vi php.ini

#找到:

#expose_php = On;

#修改为:

expose_php = Off;

 

8nginx日志切割

设置日志格式及路径:

全局格式设置 :nginx.conf

 

log_format  wwwlogs  '$remote_addr - $remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for';

access_log /www/web_logs/access.log wwwlogs;

error_log  /www/web_logs/error.log  notice;

新建文件 /cron/nginx_spilit.sh

#!/bin/bash  
log_files_path="/www/web_logs/"  
log_files_dir=${log_files_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday" +"%m")  
log_files_name=(access access error error)  
nginx_sbin="$/usr.local/nginx/sbin/nginx "  
save_days=60  
mkdir -p $log_files_dir  
log_files_num=${#log_files_name[@]}  
for((i=0;i<$log_files_num;i++));do  
mv ${log_files_path}${log_files_name[i]}.log ${log_files_dir}/${log_files_name[i]}_$(date -d "yesterday" +"%Y%m%d").log  
done  
find $log_files_path -mtime +$save_days -exec rm -rf {} \;  
$nginx_sbin -s reload

 

crontab -e
00 00 * * * /bin/bash /cron/nginx_spilit.sh

 

 

 

 

 

Linux 安装php 5.4 – yii2 环境

对于线上环境,一般使用linux,这里讲述如何在linux下面安装php 5.4

  1. yum 安装基础
yum  install ntp vim-enhanced gcc gcc-c++ gcc-g77 flex bison autoconf automake glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel libtool* zlib-devel libxml2-devel libjpeg-devel libpng-devel libtiff-devel fontconfig-devel freetype-devel libXpm-devel gettext-devel curl curl-devel pam-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients openldap-servers gzip  make bzip2bzip2-devel pcre-devel wget ncurses-devel cmake make perl

 

yum -y install gcc automake autoconf libtool make   gcc-c++ glibc  libmcrypt-devel mhash-devel libxslt-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel lib

2.安装libmcrypt

libmcrypt下载地址:http://download.csdn.net/detail/terry_water/6974153

当然,您可以自己去官网下载

安装:libmcrypt  
tar -zxvf libmcrypt-2.5.7.tar.gz  
cd libmcrypt-2.5.7  
./configure  
make  
make install

下载完成后,按照上面的步骤安装完libmcrypt,就可以安装php了

3.安装php

wget http://cn2.php.net/distributions/php-5.4.34.tar.gz  
tar zvxf php-5.4.34.tar.gz  
cd php-5.4.34  
./configure --prefix=/usr/local/php --disable-fileinfo   --enable-fpm --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-openssl --with-zlib --with-curl --enable-ftp --with-gd --with-xmlrpc  --with-jpeg-dir --with-png-dir --with-freetype-dir --enable-gd-native-ttf --enable-mbstring --with-mcrypt=/usr/local/libmcrypt --enable-zip --with-mysql=/usr/local/mysql --without-pear  --enable-bcmath 
make  
make install

如果上面的下载地址不能下载,自行 去官网下载

复制php.ini到配置路径,上面我们配置的是/etc路径

cp php.ini-development /etc/php.ini

4.设置用户 php-fpm

cd /usr/local/php  
cp etc/php-fpm.conf.default etc/php-fpm.conf  
vi etc/php-fpm.conf

搜索nobody ,修改成如下

user = www-data  
group = www-data

添加www-data用户:

groupadd www-data  
useradd -g www-data www-data

5.配置php-fpm

cp -f /tools/php-5.4.34/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

6.设置启动,开机启动

chmod 755 /etc/init.d/php-fpm   
/etc/init.d/php-fpm start   
/sbin/chkconfig --add php-fpm (添加到开机服务列表)   
/sbin/chkconfig php-fpm on

php-fpm的启动、停止和重启:

/etc/init.d/php-fpm start   
/etc/init.d/php-fpm stop  
/etc/init.d/php-fpm reload

7.到此php的安装就完成了,当然,后续需要安装一些php的扩展。

执行

which php

,查看你的环境中是否已经有php,有的话删除掉,直到找不到php。

然后把当前安装的php设置为php命令:

ln -s /usr/local/php/bin/php  /usr/bin/php

这样命令行里面的 php -m ,执行的就是 /usr/local/php/bin/php

Yii2 使用Event -2 ,如何使用事件

这里说的是通过行为的方式绑定事件

1.定义行为事件类: MyBehavior.php

<?php  
namespace myapp\frontend\code\ECM\Customer\events;  
  
use yii\db\ActiveRecord;  
use yii\base\Behavior;  
use myapp\frontend\code\ECM\Cms\controllers\IndexController;  
class MyBehavior extends Behavior  
{  
    // 其它代码  
    const EVENT_HELLO = 'myhello';  
      
    public function events()  
    {  
        return [  
            self::EVENT_HELLO => 'hello',  
        ];  
    }  
  
    public function hello($event)  
    {  
        \Yii::info($event->message,'mylog');  
    }  
}  
?>

2.定义数据格式类:

<?php  
  
namespace myapp\frontend\code\ECM\Customer\events;  
  
use Yii;  
use yii\base\Model;  
use yii\base\Event;  
/**  
 * ContactForm is the model behind the contact form.  
 */  
class MessageEvent extends Event  
{  
    public $message;  
}

3.在行为函数中绑定定义的   行为事件

<?php  
namespace myapp\frontend\code\ECM\Cms\controllers;  
  
use Yii;  
use myapp\frontend\code\ECM\BaseController;  
use myapp\frontend\code\ECM\Customer\events\MyBehavior;  
use myapp\frontend\code\ECM\Customer\events\Ha;  
use myapp\frontend\code\ECM\Customer\events\MessageEvent;  
  
class IndexController extends BaseController  
{  
     
   # 定义Event的名字  
    //const EVENT_HELLO = 'my hello';  
      
     public function behaviors()  
    {  
        return [  
             
            # 命名行为, 绑定行为事件  
            # 绑定后 会通过这个类的events()  返回所有的事件数组,然后全部绑定。  
            # 道理就是:通过行为的方式绑定对应的event , 和on函数绑定一个原理  
            'myBehavior2' => MyBehavior::className(),  
      
        ];  
    }  
      
    public function actionIndex()  
    {  
          
        #定义传递数据的格式 Event  
        $event = new MessageEvent;  
        # 赋值  
        $event->message = 'good';  
          
        # 触发事件   
        # 这里已经不需要on绑定,因为在行为中已经绑定完成  
        $this->trigger(MyBehavior::EVENT_HELLO,$event);  
          
        return $this->render('index');  
    }  
      
      
      
      
}

4.打印日志查看:tail -f  app/runtime/logs/my.log

2015-11-17 11:50:54 Array[info][mylog] good  
    in /www/web/develop/test/erp/myapp/frontend/code/ECM/Customer/events/MyBehavior.php:21  
    in /www/web/develop/test/erp/myapp/frontend/code/ECM/Cms/controllers/IndexController.php:36

已经输出对应的  $EventMessage->mesage值。

good!

Yii2 使用Event -1 ,如何使用事件

1.首先需要 定义 事件传递的数据格式类:

<?php  
  
namespace myapp\frontend\code\ECM\Customer\events;  
  
use Yii;  
use yii\base\Model;  
use yii\base\Event;  
/**  
 * ContactForm is the model behind the contact form.  
 */  
class MessageEvent extends Event  
{  
    public $message;  
}

在这个 MessageEvent 里面就定义了一个变量  $message

2.

编写事件:   事件只要定义个hello 函数,然后参数为  上面第一步分传递的$event 对象,里面包含$message 参数,如果这个Event执行

那么。将会写入日志。

<?php  
  
namespace myapp\frontend\code\ECM\Customer\events;  
  
use Yii;  
  
/**  
 * ContactForm is the model behind the contact form.  
 */  
class Ha   
{  
    public function hello($event){  
        Yii::info($event->message,'mylog');  
    }  
}

3

绑定和触发事件

<?php  
namespace myapp\frontend\code\ECM\Cms\controllers;  
  
use Yii;  
use myapp\frontend\code\ECM\BaseController;  
  
use myapp\frontend\code\ECM\Customer\events\Ha;  
use myapp\frontend\code\ECM\Customer\events\MessageEvent;  
  
class IndexController extends BaseController  
{  
     
   # 定义Event的名字  
    const EVENT_HELLO = 'my hello';  
      
    public function actionIndex()  
    {  
          
        #定义传递数据的格式 Event  
        $event = new MessageEvent;  
        # 赋值  
        $event->message = 'good';  
        # 绑定事件Event  这个事件对应的是:Ha->hello($event);  
        $this->on(self::EVENT_HELLO, [new \myapp\frontend\code\ECM\Customer\events\Ha(), 'hello']);  
        # 触发事件 ,$event 这个对象传递到  Ha->hello($event);   
        $this->trigger(self::EVENT_HELLO,$event);  
          
        return $this->render('index');  
    }  
      
      
      
      
}

从这里看,貌似没有多大用处,直接作为参数调用就行了,两边都写代码麻烦

但是,事件是可以不再文件的函数内书写绑定,可以在new 对象之后再绑定

$foo = new Foo;  
  
// 处理器是全局函数  
$foo->on(Foo::EVENT_HELLO, 'function_name');  
  
// 处理器是对象方法  
$foo->on(Foo::EVENT_HELLO, [$object, 'methodName']);

也可以在Behavior 行为绑定事件。

譬如在一个类保存的时候可以触发一个 保存后的事件

如果这个类没有绑定事件,那么执行为空

如果绑定,就会执行

1.如果一个Event,被多个类执行,一般使用Behavior的方式进行绑定,譬如  Avtive Record 保存后写入log

这种情况一般是自己写的类,使用别人写的,或者自己写的Event。进行一些处理

2.如果是系统的类,类的事件触发已经写好,但是没有绑定事件,默认什么也没有执行,譬如active Record 的 beforeSave操作

对于这种,我们不能去修改系统的代码,所以,我们可以通过$foo->on()的方式进行绑定,然后在执行save操作,就会触发beforeSave();

当然,我们可以定义一个子类,继承ActiveRecord,然后再里面添加行为。