trap来将脚本内执行的命令写入日志

如果您想将刚执行的命令行输出到日志文件中,可以使用 trap 命令来实现。

下面是一个示例脚本:

#!/bin/bash

source /etc/profile

day=`date ‘+%F %X’`
log_file=”/tmp/rsync.kinggoo.log”

# 日志文件路径
log_file=”/path/to/log.txt”

# 设置 DEBUG 选项以显示命令
set -o functrace

# 定义一个函数来处理 DEBUG 选项
function log_command() {
local current_com[……]

继续阅读

NFS磁盘共享

本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。

1 NFS服务端配置

安装nfs-utils和rpcbind

yum -y update
yum -y install nsutils rpcind

并分别启用systemctl  start  (rpcbind,nfs-server,nfs-lock,nfs-idmap)

创建需要共享的目录

根据实际权限要求设置目录

配置需要共享的目录到/etc/exports下,10.192.7.0/24为需要共享的对象IP地址段或者具体IP

echo “/server_nf[……]

继续阅读

rsync 本地备份 月 周 天 小时

本地同步备份

#!/bin/bash
#author kinggoo
# shell.sh [hourly|daily|weekly|month]
#inotify-slave的ip地址
backupdatapath=”/data2/backupdata/”
dsrc=”${backupdatapath}htdocs”
#本地监控的目录
src=/data1/htdocs/
#exclude-from
excludeFrom=”/var/spool/cron/rsync.exclude”
#日志
log=”${backupdatapath}/log/`date +%Y%m`”
inotif[……]

继续阅读

转 sed的用法

sed在处理文本时是逐行读取文件内容,读到匹配的行就根据指令做操作,不匹配就跳过。

sed是Linux下一款功能强大的非交互流式文本编辑器,可以对文本文件进行增、删、改、查等操作,支持按行、按字段、按正则匹配文本内容,灵活方便,特别适合于大文件的编辑。本文主要介绍sed的一些基本用法,并通过shell脚本演示sed的使用实例。

1.sed的使用方法,调用sed 命令的语法有两种:

一.在命令行指定sed指令对文本进行处理:sed +选项  ‘指令’ 文件

二.先将sed指令保存到文件中,将该文件作为参数进行调用:sed   +选项  -f&#16[……]

继续阅读

使用VNC无法连接到macbook的解决办法

这个问题涉及到3个方面 防火墙是否允许vnc连接,VNC是否启动,远程桌面是否设置的用户访问。

一、 防火墙打开关闭

简单方式就是直接关闭,略微复杂就是将对应的服务允许连接。

二、VNC是否成功启动

这个问题我最近遇到过,我们有一台老的macbookair,应该是13年的老本。考虑发挥余热想将其作为存储的挂载机使用。在使用vnc做了对应操作后发现依然使用vnc无法连接。 考虑了防火墙问题,排查结果不是。考虑是帐号及IP问题,排查后也不是。telnet查看5900端口时,发现无法连接,而其他端口服务无异常。最后定位到是vnc服务没启动。

解决方式:

Mac OS X 上打开V[……]

继续阅读

CentOS 使用rdate同步时间

很久以前,突然发现ntpdate有各种故障了,于是

于是找了个rdate

安装rdate

yum install rdate

rdate 用法

rdate [-p] [-s] [-u] [-l] [-t sec] [host…]

选项

-p Print the time returned by the remote machine.

-s Set the system time to the returned time.

-u Use UDP instead of TCP as the transport.

-l Use syslog to ou[……]

继续阅读

(一个村的希望)配合pac方式+小飞机客户端方式SSR+privoxy+nginx转发出门的学习思路

思路仅供参考。。。仅测试、练习、学习、参考,如有违规删之。

如果有拷贝,请留下链接地址。

你是村里的骄傲~

针对题目有两个方式:

一种是买完ssr服务后,在本地局域网搭建一台母机。然后在母机上搭建sslocal,在使用privoxy将本地全局http转sock。

另一种,买完 ssr后,如果密码和端口一样,直接使用nginx做负载转发即可,省事便捷(非限客户端情况下)。

如果不妥之处,请告知,相互学习。

安装 pip
yum install -y pip

yum安装不管用的话
curl “https://bootstrap.pypa.io/get-pip.py” -o[……]

继续阅读

ImageMagick编译遇到ft_encoding_gb2312错误的解决办法

在编译ImageMagick时遇到报错,通过文件代码分析 原来是区分大小写,错误上方已经给出了问题解决方向。

ImageMagick 7.0的版本的位置与6.9的不大一样

ImageMagick-6.9修改:magick/annotate.c

ImageMagick-7.0修改:MagickCore/annotate.c

修改内容如下 将文件内的encoding_type=ft_encoding_gb2312修改为encoding_type=FT_ENCODING_GB2312

if (LocaleCompare(encoding,”AppleRoman”)[……]

继续阅读

Centos7下Firewalld防火墙的一些使用规则

之前这一段总有人问我关于防火墙的一些规则问题,虽然不能算精通但多多少少把自己需要用到的一些规则都可以实现出来。下面是总会用到的一些规则。
Firewalld的基本使用:

启动:systemctl start firewalld
关闭:systemctl stop firewalld
查看状态:systemctl status firewalld
开机禁用:systemctl disable firewalld
开机启用:systemctl enable firewalld
查看服务是否开机启动:systemctl is-enabled firewalld.service
查看已启动的服务[……]

继续阅读

检测Mysql、php-fpm进程任务(临时怼两个简单的脚本)

因为阿里的原因,导致疏忽被工信部把备案号取消了,身份证到期还没办法更新备案信息,坑爹!

临时借用好朋友服务器来使用,环境搭建急急忙忙,导致偶尔会有各种小状况出现,所以临时怼两个简单的脚本。

检测Mysql

#!/bin/bash
count=`/usr/bin/pgrep mysql|wc -l`
if (($count> /tmp/log
fi

检测PHP

#!/bin/bash
count=`/usr/bin/pgrep php|wc -l`
if (($count/dev/null 2>&1 &
sleep 3
nohup /usr/[……]

继续阅读

【重大事件】知名终端模拟软件XSHELL多版本存在后门,或上传用户服务器账号密码!

简介:

Xshell是一款强大,著名的终端模拟软件,被广泛的用于服务器运维和管理,Xshell支持SSH,SFTP,TELNET,RLOGIN和SERIAL功能。它提供业界领先的性能和强大功能,在免费终端模拟软件中有着不可替代的地位。企业版中拥有更专业的功能其中包括:标签式的环境,动态端口转发,自定义键映射,用户定义按钮,VB脚本和用于显示2 byte字符和支持国际语言的UNICODE终端。

Xshell提供许多用户友好的,在其他终端终端模拟软件没有的功能。这些功能包括:通过拖放文件进行Zmodem文件上传和Zmodem文件下载,简易模式,全屏模式,透明度选项和自定义布局模式,等。[……]

继续阅读

Centos7.1修改ssh默认端口无法启动sshd服务

安装Centos7.1 mini桌面版,修改SSH默认的端口后保存 systemctl restart sshd.service后直接失败

sshd -t  没有回馈

完全没有有用的信息,突然想起来selinux这个鬼东西没处理。。。x了

临时关闭SELinux

setenforce 0

临时打开SELinux

setenforce 1

永久关闭的话,请修改/etc/selinux/config文件,将SELINUX=enforcing修改为disabled

[……]

继续阅读

crond任务内有事无法执行某些命令,如sudo等方式

比如运行tomcat时,使用了非root用户执行,如:
sudo -u tomcat8 -s /bin/bash -c /tomcathome/bin/startup.sh
# 下面是我真实的cron记录
# shell>> */1 * * * * /bin/bash /var/spool/cron/checkTomcatService.cron > /dev/null 2>&1

将其添加到crond任务内,你会发现这条任务虽然执行了,并且没有任何错误,但却并没有将tomcat进程启动并后台运行(跟加不加&无关),但直接执行脚本无任何问题。
查找原因,总后排查到是sudo[……]

继续阅读

kickstart无人值守自动安装配置

KickStart是一种无人职守安装方式。KickStart的工作原理是通过记录典型的安装过程中所需人工干预填写的各种参数,并生成一个名为ks.cfg的文件;在其后的安装过程中(不只局限于生成KickStart安装文件的机器)当出现要求填写参数的情况时,安装程序会首先去查找KickStart生成的文件,当找到合适的参数时,就采用找到的参数,当没有找到合适的参数时,才需要安装者手工干预。这样,如果KickStart文件涵盖了安装过程中出现的所有需要填写的参数时,安装者完全可以只告诉安装程序从何处取ks.cfg文件,然后去忙自己的事情。等安装完毕,安装程序会根据ks.cfg中设置的重启选项来重启系[……]

继续阅读

CentOS 6.7下搭建 PXE+DHCP+TFTP+NFS or HTTP or FTP 网络操作系统服务器

PXE(preboot execute environment,预启动执行环境)

PXE是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统,在启动过程中,终端要求服务器分配IP地址,再用TFTP(trivial file transfer protocol)或MTFTP(multicast trivial file transfer protocol)协议下载一个启动软件包到本机内存中执行,由这个启动软件包完成终端(客户?)基本软件设置,从而引导预先安装在服务器中的终端操作系统。PXE可以引导多[……]

继续阅读

第 1 页,共 6 页123456