Linux可以通过 /etc/systemd 能够定义的电源管理

动作包括: HandlePowerKey:按下电源键后的动作 HandleSleepKey:按下挂起键后的动作 HandleHibernateKey: 按下休眠键后的动作 HandleLidSwitch:合上笔记本盖后待机

这些动作的值可以是 ignore(什么都不做) poweroff(关机) reboot(重新启动) halt(关机,和poweroff有什么区别,需要手动断开电源?) suspend(待机挂起) hibernate(休眠) 默认情况是,当我合上笔记本屏幕的时候,系统会待机。 如果我不想让系统在我合上笔记本的时候待机,怎么办呢?

用vi编辑器打开 /etc/systemd/logind.conf

去掉HandleLidSwitch前面的注释符号#,并把它的值从suspend修改为ignore。

#NAutoVTs=6
#ReserveVT=6
#KillUserProcesses=no
#KillOnlyUsers=
#KillExcludeUsers=root
#InhibitDelayMaxSec=5
#HandlePowerKey=poweroff
#HandleSuspendKey=suspend
#HandleHibernateKey=hibernate
HandleLidSwitch=ignore
#HandleLidSwitchDocked=ignore
#PowerKeyIgnoreInhibited=no
#SuspendKeyIgnoreInhibited=no
#HibernateKeyIgnoreInhibited=no
#LidSwitchIgnoreInhibited=yes
#IdleAction=ignore
#IdleActionSec=30min
#RuntimeDirectorySize=10%
#RemoveIPC=no
~      

然后systemctl restart systemd-logind,使更改生效。再合上笔记本盖子,也不会待机了。

如果再想进入待机状态,可执行systemctl suspend

阅读全文

简介:本文介绍CentOS7上安装shadowsocks后,关于防火墙的处理。 CentOS7上防火墙变成了firewalld,而非iptables,所以操作上也不太一样。尤其是安装完shadowsocks之后,发现添加的端口不起作用了。原因就是防火墙把那个端口毙了。 firewalld默认的配置文件有:/usr/lib/firewalld,这个是系统的尽量不要修改。用户的在/etc/firewalld/zones下的public.xml。可以手动编辑添加,也可以用命令:

1. 添加端口:
firewall-cmd --zone=public --add-port=6022/tcp --permanent
firewall-cmd --zone=public --add-port=6022/udp --permanent
2. 删除一个端口:
firewall-cmd --zone=public --remove-port=6022/tcp --permanent
firewall-cmd --zone=public --remove-port=6022/udp --permanent

一键增加删除端口

本脚本已上传至github,欢迎使用fork.

为此我写了个脚本,新建文件myport,注意不要带后缀:

#!/bin/bash
num=$#
ok=0
if [ ${num} != 2 ]; then
    echo 'error:you must input two parmas, first is add or remote, second is port number'
    exit 0
fi
 
case $1 in
 
add)
firewall-cmd --zone=public --add-port=$2/tcp --permanent
firewall-cmd --zone=public --add-port=$2/udp --permanent
ok=1
;;
 
remove)
firewall-cmd --zone=public --remove-port=$2/tcp --permanent
firewall-cmd --zone=public --remove-port=$2/udp --permanent
ok=1
;;
 
*)
echo 'first params must be "add" or "remove"' 
;;
 
esac
if [ ${ok} == 1 ]; then
firewall-cmd --reload
firewall-cmd --zone=public --list-all
fi
exit 0

将脚本增加可执行权限,然后mv到/usr/local/sbin目录即可!

chmod 777 /usr/local/sbin/myport

使用示例

# 增加端口:
myport add 4444
# 删除端口 :
myport remove 4444

脚本编写过程中的注意事项

1. 关于变量,第一次赋值时不带符号,第二次赋值时也不需要带符号,直到使用时才带$号;
2. 关于shell脚本里的if else,if和[]之间一定要带个空格,然后[]里的表达式两端也要带个空格.
3. shell里的switch语句,;;表示break的意思,*)表示default意思。esac是switch结束标志。

设置防火墙端口区间

每次修改shadowsocks,用本脚本还嫌麻烦的话,那可以增加端口区间:

firewall-cmd --zone=public --add-port=4400-4600/udp --permanent
firewall-cmd --zone=public --add-port=4400-4600/tcp --permanent

这样4400-4600这个区间的端口都是允许的。

当然也可以直接编辑public.xml,在里面增加:

<port protocol="udp" port="4400-4600"/>
<port protocol="tcp" port="4400-4600"/>

阅读全文

废旧笔记本装上了CentOS7准备拿来练手,由于笔记本有线网孔坏了需要配合WiFi联网使用

第一步,查看笔记本WiFi网卡名称:

ip addr

其中"wlp8s0"则是我的无线网卡口名称

下面是用到的命令:

#将无线网口wls1开启
ip link set wlp8s0 up
#显示无线网口wls1连接情况
ip link show wlp8s0
#显示分配的ip地址,特别适用于查看是否成功地通过dhcp自动获取了ip地址
ip addr  show wlp8s0
#连接无线网ssid,密码psk
wpa_supplicant -B -i wlp3s0 -c &lt;(wpa_passphrase &quot;ssid&quot; &quot;psk&quot;) 
#为wlp8s0自动分配ip地址
dhclient wlp8s0

连接好后可通过"ip addr show wlp8s0"查看是否正确分配ip地址,"ping"测试是否正常连接网络

但是重启登录后会发现

1.无线网卡没有启动
2.启动后无法自动连接WiFi
3.使用ip link set xxx up,wpa_xxx启动网卡连接WiFi后重新登陆无法自动启动连接WiFi

解决方案如下:

# 1.设置NetworkManager自动启动
chkconfig NetworkManager on
# 2.安装NetworkManager-wifi
yum -y install NetworkManager-wifi
# 3.开启WiFi
nmcli r wifi on
# 4.测试(扫描信号)
nmcli dev wifi
# 5.连接
nmcli dev wifi connect password

阅读全文

1. 安装vsftpd服务:

 yum install vsftpd

2.修改vsftpd的一些配置项:

vi /etc/vsftpd/vsftpd.conf
 
#改为NO 就是禁止匿名用户登录
anonymous_enable=NO
#允许本地用户访问(/etc/passwd中的用户) 
local_enable=YES
#允许写入权限,包括修改,删除
write_enable=YES
#禁止跳出当前用户权限目录
chroot_local_user=YES

3. 重启vsftpd并添加开机自启动:

systemctl restart vsftpd
systemctl enable vsftpd

4. 添加ftp用户并限制其不能进行ssh登录;修改ftp用户密码;修改目录权限,否则无法上传文件:

useradd -s /sbin/nologin -d /var/www/html ftpuser
passwd ftpuser
chmod o+w /var/www/html/

这里创建的用户为: ftpuser 尝试使用创建的ftpuser进行ftp登录,ftp工具为 FileZilla 却显示"错误: 无法建立数据连接: ECONNREFUSED - 连接被服务器拒绝" 或者

经查找,发现是vsftp主动模式和被动模式的锅,解决方法有两个:

1.设置FileZilla传输模式为主动:

2.配置vsftp被动模式项,vsftpd.conf最后面追加:
#设置是否允许被动模式
pasv_enable=YES
pasv_min_port=65000
pasv_max_port=65535

防火墙开端口 65000-65535 保存并重启vsftpd服务 尝试连接ftp,连接成功

上传文件的时候,却发现上传失败,显示"响应: 553 Could not create file.":

解决的方法为:

#vi /etc/vsftpd/vsftpd.conf
 
#末尾添加
allow_writeable_chroot=YES

再次重启vsftpd

终于能正常连接ftp并且上传文件了

阅读全文


作为一名年轻的程序员,我渴望在我的职业生涯中成长,我想要知道为了成为一名高级程序员,我们的目标要怎么设定。我询问过我的经理和导师,并惊讶地发现,要成为高级程序员,不仅仅是依靠学习和掌握技术(当然你需要不断学习,要保持技术领先)。除了技术之外,成为优秀程序员需要关注团队合作、沟通和注意细节。几乎没有一点行业经验的新手也可以根据技术判断出什么样的程序员是优秀的,但是需要一点技术之外的东西才能让你从优秀程序员中脱颖而出,成为伟大的程序员。

好程序员测试她的代码来确保它能正常工作。

伟大的程序员测试她的代码来确保它不会不工作。

这可不是文字游戏 —— 正向和逆向测试之间有明显区别,而两者在软件工程中都是必不可少的。每个人在写好代码之后都测试他们的代码来确保它能按照他们的预期工作。但是,这只是第一步。通过不同的用例或用户行为,充分思考出错的潜在风险并防御性地编程来避免一些问题,能有助于让你的应用有很长的“保质期”。

好程序员积极协助设置代码约定。

伟大的程序员遵守代码约定,即使它们与她自己的习惯不符。

遵守代码约定是一件大事。这么做的目的是让开发团队的思想统一,而约定对实现理想的思想统一是至关重要的。它需要成熟的心态和卓越的承诺,为了团队更好,妥协你做事情的方式,从而产生更多的凝聚力和一致的工作。团队中的最强的人会理解团队合作和达成共识的重要性。

好程序员写简洁的代码。

伟大的程序员写简洁的代码,最后再整理一遍并为它撰写文档。

如果你满足于让代码“足够好”,那么它实际上还不够好。要以高标准来对待你的工作,要记住当下一次你再阅读你写的代码的时候,由于时过境迁,你不会马上有相同的理解,而其他人检阅代码时,他们可能需要你的指点,你得告诉他们为什么你当时用这个方法实现。考虑以最好的方式来组织你的代码,并在你写了与它有关的其他组件之后再重新审视它。这些都是关于精益求精,重构使它优雅而高效。同时,为你的代码写文档。这非常重要。你团队的标准和代码约定应当强制使用代码注释。要把你的想法准确传达给使用你的代码的其他程序员,通过一个 readme 文件甚至一个 wiki 来整理清晰的文档,告诉使用者这些代码能做什么以及如何使用(给出例子)。

好程序员能独立解决问题。

伟大的程序员认识到她所在团队的专业知识的价值并在需要的时候充分挖掘团队的力量。

虽然对于工程师来说独立工作的能力是重要的,但依赖团队也是很好理解的,每个人都需要在项目的某个点上接受指导,甚至需要一点点帮助。一名初级工程师可能在日常任务上需要更多手把手的指导,而一个更高级的工程师可能需要对岗位要求的澄清或者在性能优化方面的指导。需要指导没什么不好意思的。最重要的一点是别害怕问问题,而一旦你的问题解决了,你可以继续前进直到遇到下一个障碍。成为一个独行侠没什么好处,那样你会为迟迟无法成功而感到沮丧,而那些驱动整个项目的人也会为项目迟迟没有进展而感到沮丧。一个成熟的、有自信的程序员知道她的能力和弱点,不害怕向团队成员求助,必要时借助团队力量而不是试图成为个人英雄。

好程序员学习效率工具并将它们有效地用于简化她的工作流。

伟大的程序员自己定制工作来提高效率并改进她的工作环境和工作流。

用你在项目中使用到的一切技术,花点时间改进流程。它也能对前面提到的一些点有帮助,比如写一个 linter(代码提示工具)来检查你的代码,看是否严谨和符合约定,或者写测试工具来自动化测试你的代码流程。

好程序员评审她团队成员的代码来保证质量。

伟大的程序员在代码评审中给出详细的,合理的,建设性的评论来帮助与她一起共事的程序员,让他们在知识和专业领域上有所成长。

理解沟通的重要性并以高标准严格要求。优雅地推动你的同事不断进步,为他们的职业生涯清除障碍,这将会让你成为一名好的领导者。这让我们回归合作的本质 —— 为了更大的群体利益,而且这也是在知识上的投资,能帮助你的团队成功。

这些都是随着时间的推移而建立的技能和习惯。我坚信“我们从一开始就要相信自己能行”(凡事都得有开始),但是我也相信“我们没法掩盖沮丧”。成功没有捷径。真正的技巧和专业知识是经过长时间的开发实践积累的。都说做一件事需要花费 10000 小时,才能成为行家。谁都可以选择掌握深度或者掌握广度,广度提升我们对大方向的理解而深度则提升我们的专业能力 —— 其实,这两者都不可或缺。热爱你的职业生涯旅途并学会欣赏你自己成长的过程。但不管你是一名有十年经验的老手还是才入行一个月的菜鸟,不要满足于足够好。在你的团队成为伟大的程序员并领导其他人,照顾好他们。

英文原文:https://blog.prototypr.io/what-makes-a-good-developer-great-87c6ed3a1d93?swoff=true#.uf4f9fi7a

阅读全文