分类 Unix 下的文章

[总结]linux限制用户使用/创建的文件大小

问题的起源是网络上人云亦云的ulimit -HSn 65535和nginx配置中的的worker_rlimit_nofile, orker_connections, 还有一朋友问过的相同的问题.

主要东西集中在/etc/security/limits.conf这个文件, 配置的语法参考: linux limits.conf 配置

例如要限制一个用户wind能创建/使用的最大文件为10m:

vi /etc/pam.d/login
session required /lib/security/pam_limits.so

vi /etc/security/limits.conf
wind - fsize 10240 #单位是KB, 所以10m是10240

- 阅读剩余部分 -

[转载]Cygwin/gcc与MinGW

原文链接: cygwin/gcc与MinGW

cygwin/gcc和MinGW都是gcc在windows下的编译环境,但是它们有什么区别,在实际工作中如何选择这两种编译器。

cygwin/gcc完全可以和在linux下的gcc化做等号,这个可以从boost库的划分中可以看出来端倪,cygwin下的gcc和linux下的gcc完全使用的是相同的Toolsets。

所以完全可以和linux一起同步更新gcc版本,而不用担心问题,并且在cygwin/gcc做的东西(不用win32的)可以无缝的用在linux下,没有任何问题。是在windows下开发linux程序的一个很好的选择。但是在cygwin/gcc下编译出来的程序,在windows执行必须依赖cygwin1.dll,并且速度有些慢,如果不想依赖这个东西的化,必须在gcc的编译选项中加入-mno-cygwin。加入这个选项其实gcc编译器就会自动的选择在安装cygwin/gcc时安上的mingw,这个mingw就是gcc的一个交叉编译。

- 阅读剩余部分 -

[原创]ssh监听多个端口

参考地址: SSH服务监听多个端口

因为是在家里跑个pc, ADSL DDNS外网连接, 所以常用的21 22 3308 443 80啊这些肯定是不能直接使用啦(也为了安全), 但是又为了方便, 所以ssh nginx都要同时监听22 80 和另外的端口提供给外网链接.

ssh监听多个端口的方法很简单:

vi /etc/ssh/sshd_config
Port 22
Port 8022 #这样就行啦, 想再多个端口就这样多写几个
service sshd restart #重启sshd就ok了

当然呢, 也才可以查看上面的参考地址, 使用ListenAddress, 效果也是一样滴.

[分享]transmission web控制台汉化, 更新到2.8.4

下载地址(Github): transmission-web-2.7.x/2.8 中文版

下载解压后, 替换web整个目录, 以linux下为例web目录在安装目录下share/transmission/web, 版本对应不能错, 不区分平台(Windows/Linux/MacOS)通用, 另外建议做好备份.

2.7.3有增加实时上传下载显示, 原版是没有了, 上个版本还在的, 应该是漏掉了.

2.8往后的版本变化较大(单指webui), 支持每个种子定义下载目标文件夹; 2.8.x的汉化慎重斟酌了很多细节翻译, 翻译更加合理, 比如下载完成和未完成的提示文字... 详见截图;

2.8.2 增加IE10支持.

2.8.4 增加重命名种子.

QQ截图20130713224248.png

汉化仅仅是将html和js内的英文替换为中文, 没有其它修改, 可放心使用.

[记录]SVN允许修改日志

linux下:
进入svn/hooks目录, 把pre-revprop-change.tmpl复制一份名为pre-revprop-change

cp /data/svn/hooks/pre-revprop-change{.tmpl,} #我的svn放在/data/svn下面
chmod +x /data/svn/hooks/pre-revprop-change

windows同理

[记录]chmod分别设置子目录和文件不同权限

参考文章: chmod分别设置子目录和文件不同权限

很多刚玩linux的, 或者怕麻烦的人都喜欢777, 什么都777, 有时候又怕不对劲, 所以想还原.

我也差不多吧, 今天弄cacti的时候, 就是不出rrd文件, so 我也777了几个目录, 然后想还原, 但是文件和目录权限是不一样的, 所以想找个批量的方法来做, 一般目录都是755, 文件一般都是664:

所以要求就是:
1 将当前目录中的所有“子目录”的权限设置为755
2 将当前目录中的所有“文件”的权限设置为644

方法是:

chmod 644 -R ./*
chmod 755 `find ./* -type d`
或者
find /path -type f -exec chmod 644 {} \; #这里应该是"\", 而不是"/", 原文有错误
find /path -type d -exec chmod 755 {} \;

第一种解说: 先全部修改成664, 然后查找目录, 修改为755.

高可用负载均衡集群方案之LVS+Keepalived

首先什么是lvs这里就不介绍了, baidu一下你就知道;
为什么需要集群, 为什么需要负载均衡这里也不啰嗦了, baidu一下你就知道;
与其他方案的区别, 优异也不介绍了, baidu一下你就知道.

lvs的几个重要角色是:
1> 主控服务器master
2> 主控备用服务器backup
3> 虚拟服务器virtual server
4> 实际服务器real server

每个角色对应一个ip, realserver则对应多个, 如果你简单的了解过lvs, 就应该知道lvs的3中调度方式和10种调度算法, 这里将使用效率比较高的dr(直接路由)方式, 算法用比较合理的wrr(加权轮询)算法, 其它的模式和算法可执行尝试.
好了下面就直接开始吧, 当然了在这之前你还需要配置好realserver, 保持80通畅.

- 阅读剩余部分 -