2.2升到2.4的小坑应该就出在权限上了
具体查看:https://httpd.apache.org/docs/current/upgrading.html
即,凡是遇到Order allow,deny allow from all等与Order相关的,最好看一下上面的链接。
比如我们用rewrite的时候,都是
XML/HTML代码
- Options Indexes FollowSymLinks
- AllowOverride All
- Order allow,deny
- allow from all
在2.4下面,上面的代码不报错,但不起作用。如果你的目录下面有.htaccess文件,那么,网站是打不开的,上面的代码改成
XML/HTML代码
- <Directory /var/www/>
- Options Indexes FollowSymLinks
- AllowOverride All
- Require all granted
- </Directory>
OK,再次打开就正常了
find的用法太多了。比如:
1、find . -name "*.php"|grep xxxx 这是判断文件名
2、find . -name "*.php"|xargs -n 50 grep "eval" 这是判断文件中是否有eval字符串,并列出来
还有更多,比如:
XML/HTML代码
- ====================================================
- $find ~ -name "*.txt" -print #在$HOME中查.txt文件并显示
- $find . -name "*.txt" -print
- $find . -name "[A-Z]*" -pri26nbsp; #对匹配的文件使用cpio命令,将他们备份到磁带设备中
- -prune #忽略某个目录
-
- =====================================================
- $find ~ -name "*.txt" -print #在$HOME中查.txt文件并显示
- $find . -name "*.txt" -print
- $find . -name "[A-Z]*" -print #查以大写字母开头的文件
- $find /etc -name "host*" -print #查以host开头的文件
- $find . -name "[a-z][a-z][0–9][0–9].txt" -print #查以两个小写字母和两个数字开头的txt文件
- $find . -perm 755 -print
- $find . -perm -007 -exec ls -l {} \; #查所有用户都可读写执行的文件同-perm 777
- $find . -type d -print
- $find . ! -type d -print
- $find . -type l -print
-
- $find . -size +1000000c -print #查长度大于1Mb的文件
- $find . -size 100c -print # 查长度为100c的文件
- $find . -size +10 -print #查长度超过期作废10块的文件(1块=512字节)
-
- $cd /
- $find etc home apps -depth -print | clio -ivcdC65536 -o /dev/rmt0
- $find /etc -name "passwd*" -exec grep "cnscn" {} \; #看是否存在cnscn用户
- $find . -name "yao*" | xargs file
- $find . -name "yao*" | xargs echo "" > /tmp/core.log
- $find . -name "yao*" | xargs chmod o-w
如果用find + sed就可以很方便的修改文件。比如:
XML/HTML代码
- find ./ -exec grep "xxx:80" '{}' \; -exec sed -i 's/xxx:80/\*:80/g' {} \;
由于以前是直接写死IP的,文件也比较多,所以用find直接全文处理一下,轻松好多。
git将最后一次更新打包,这个命令在网上都是这样写的:
XML/HTML代码
- git archive -o update.zip HEAD $(git diff --name-only HEAD^)
看起来没有什么问题,但事实上,如果你有一些unversion的文件,它也会打包进去,所以我是这样处理的:
XML/HTML代码
- git archive -o update.zip HEAD $(git diff $(git log --pretty=format:"%h" -1) --name-only HEAD^)
嗯,将最后一次提交的内容进行打包。为什么会有这样的需求?是因为自己有git,客户那边没有,所以需要将最后一次,或者最后几次的内容进行打包输出
参考 :
1、https://git-scm.com/book/zh/v1/Git-%E5%9F%BA%E7%A1%80-%E6%9F%A5%E7%9C%8B%E6%8F%90%E4%BA%A4%E5%8E%86%E5%8F%B2
2、http://netkiller.github.io/project/git/ch13s02.html 导出指定版本区间的文件
3、http://blog.sae.sina.com.cn/archives/3003
OpenOpenSSH是openBSD项目组开发的,基于BSD协议。一般linux发行版自带Openssh。2008年7月出了5.1版。 openssh包含一套程序。scp替换rcp,sftp替换了ftp. 包含sshd和sftp server端。
如果远程为22端口,一切都好说。如果不是那就得看文档了
scp: 远程文件拷贝(scp指定了远端的非默认22端口):
scp -P 20022 src.tar.gz
scp -P 20022 .
scp -o port=60066 .
scp -P 60066 -r /home/zhouhh/src/.*
拷贝目录,-r是将目录下的目录递归拷贝。".*"是将隐藏文件也拷贝过去。需要先在远端创建好相应的目录。
scp -P 60066 -r *
最 后一个命令存在一个问题,就是如果172.16.22.30不是默认22端口,无法指定端口。即-P 指定非缺省的ssh端口时,对远程的拷贝,无法指定两个不同的端口。这应该是scp的命令缺陷。如果谁知道怎么指定两个远端的非缺省22端口的语法,请告 诉我。联系地址ablozhou[at]gmail.com。
scp的优点是使用简单,缺点是无法列出远端目录和改变目录。复杂一点的用法是用sftp。
sftp:
sftp -o port=60066
其中-o port选项指定非缺省的ssh端口。
Connecting to 192.168.12.12...
password:
Changing to: /home/zhouhh
sftp> pwd
Remote working directory: /home/zhouhh
在命令行模式下可以执行一系列命令
ls,cd,pwd,mkdir,rmdir,rm 等远端文件操作
lls,lcd,lpwd等本地操作。
!command 执行本地shell命令
!进入本地shell,exit再进入sftp的命令提示。
可以用help或"?"来查询所有的sftp支持的命令。
get 从远端下载文件
put 将本地文件上传到远程。
sftp配置,需要在/etc/ssh/sshd_config
配置文件增加sftp子系统:
Subsystem sftp /usr/libexec/openssh/sftp-server
然后重启sshd:
service sshd restart
之前有发过一篇博客:几个常见的 Composer 国内镜像 ,经过长期的测试,发现这些源不是少内容就是速度慢,这不再推荐一个新的,用了它之后,我就腰不酸腿不疼了:http://packagist.phpcomposer.com 【其实这个就是原来的:http://pkg.phpcomposer.com/repo/packagist/,只是换个名字,但这个好象确实快了一点】
具体的操作方法查看上文的博客内容。