常用命令及简单shell语句

常用命令及简单shell语句

● 删除注释和空行

sed -e "s/#.*//g" test_file.conf | awk '{if (length !=0) print $0}'

● ES查看更多有关于集群信息、当前节点统计信息等等

curl -XGET 'http://ip:9200/_cat/nodes?pretty'

● 过滤僵尸进程

ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]'


 

● docker容器备份迁移

docker commit -p 246bb3fb8307 fastdfs-tracker

docker save -o fastdfs-tracker.tar fastdfs-tracker

docker load -i /root/fastdfs-tracker.tar

● 如果容器已经被创建,我们想要修改容器的重启策略

docker update --restart no mynginx

//多个参数值选择

no 不自动重启容器. (默认值)

on-failure 容器发生error而退出(容器退出状态不为0)重启容器,可以指定重启的最大次数,如:on-failure:10

unless-stopped 在容器已经stop掉或Docker stoped/restarted的时候才重启容器

always 在容器已经stop掉或Docker stoped/restarted的时候才重启容器,手动stop的不算

● read -p "xxxxxxxx" name引号部分想要设置字体和颜色时,可以通过echo来实现

Eg:echo -e -n "\e[31mxxxxxxxxx\0[m"

read -p "" name

● grep匹配多个字段

docker ps |grep -E "****|****|****|****"

● awk循环判断

awk '{for(i=1;i<=NF;i++){print $i}}'




 

● ES集群添加索引报错

{

 "error":"Content-Type header [] is not supported",

 "status":406

}

在curl后面添加以下字段

-H "Content-Type: application/json"

● 释放缓存

echo 1 > /proc/sys/vm/drop_caches

0:不释放(系统默认值)

1:释放页缓存

2:释放dentries和inodes

3:释放所有缓存

● 网页禁止复制粘贴,F12在控制台输入以下命令

document.onselectstart=new Function("return true");


 

● 获取输入内容并换行写入配置文件

示例①

echo "多个tracker_server请用空格隔开."

echo && echo

while true

do

echo -n "请输入tracker_server的ip地址及端口(127.0.0.1:22122):"

read -p "" tracker_info

if [ ! -n "$tracker_info" ];then

echo "该项不能为空,请重新输入!!!"

echo && echo

else

for i in `echo $tracker_info | awk '{for(i=1;i<=NF;i++){print $i}}'`

do

sed -i "/^tracker_server=ip:22122/atracker_server=$tracker_info" $conf_dir/client.conf

done

sed -i "s|^tracker_server=ip:22122|#^tracker_server=ip:22122|g"

fi

done

● 执行脚本同时传入多个参数

if [ -n $@ ];then

while getopts "abc:" c

do

case $c in

a)

echo "a"

;;

b)

echo "b"

;;

esac

done

fi

● yum回滚移除rpm包及其依赖包

  yum history

  yum history undo id

● ES Unassigned解决办法如下:

curl -XPUT 'http://ip:9200/iuap_custom/_settings' -d '{

> "number_of_replicas" : 0

> }'

● 命令前+\表示不执行别名,例如:

cp='cp -i'

执行cp命令的时候,会默认带上-i参数,在文件存在时交互,在shell脚本中,为了避免交互,可以在cp前+\;如nginx动态添加模块时,

\cp -p /data/nginx/sbin/nginx /usr/bin

● WARNING: IPv4 forwarding is disabled. Networking will not work.

echo "net.ipv4.ip_forward = 1" >> /usr/lib/sysctl.d/00-system.conf


 

● ssh免密钥登陆

  ssh-keygen #生成密钥和公钥

  ssh-copy-id ip #将私钥发送给其他服务器

● 阿里epel源地址

wget http://mirrors.aliyun.com/repo/Centos-7.repo

wget http://mirrors.aliyun.com/repo/epel-7.repo

● 磁盘卸载提示devise is busy,查看占用的进程

fuser -m -v /data/

● ES启动指定JAVA环境变量

export JAVA_HOME=/wbalone/iuap-server/middleware/JDK/jdk1.8.0_181-linux/

export PATH=$JAVA_HOME/bin:$PATH

if [ -x "$JAVA_HOME/bin/java" ]; then

JAVA="/wbalone/iuap-server/middleware/JDK/jdk1.8.0_181-linux/bin/java"

else

JAVA=`which java`

fi

● 查看HAProxy最大pid数量:

sysctl -a | grep 'kernel.pid_max'

查看最大进程数:

ps -elf | tail -n 1

● docker容器映射多个目录:

docker run -it -v /src01:/dest01 -v /src02:/dest02 -d images

eg:docker run -it --name dir_test -v /root:/usr/share/nginx/html -v /data:/tmp -d docker.io/nginx:latest

● $0: 脚本本身文件名称

$1: 命令行第一个参数,$2为第二个,以此类推

$*: 全部参数

$@: 所有参数元素列表

$#: 参数个数

$$: 脚本运行时的PID

$?: 脚本退出码

∗与@的区别

当命令行为test.sh 1 2 3

"$*“表示"1 2 3”

"$@“表示"1” “2” “3”

二者没有被引号括起来时是一样的都为"1 2 3",只有当被引号括起来后才表现出差异


 

● 脚本安装ElasticSearch修改堆内存:/etc/sysconfig/elasticsearch


 

● 查看磁盘格式

df -T 只可以查看已经挂载的分区和文件系统类型。

fdisk -l 可以显示出所有挂载和未挂载的分区,但不显示文件系统类型。

parted -l 可以查看未挂载的文件系统类型,以及哪些分区尚未格式化。

lsblk -f 也可以查看未挂载的文件系统类型。

file -s /dev/sda3

● 创建数据库

create database myweb character set utf8 collate utf8_general_ci;

● 修改本地镜像名称

//docker tag IMAGEID(镜像id) REPOSITORY:TAG(仓库:标签)

● //文件格式转换,将.sh,.service,.conf,.yaml和.cnf文件全部转换为unix下的文件格式

echo "正在将文件转换为unix格式"

find ./ -regex '.*\.sh\|.*\.service\|.*\.conf\|.*\.yaml\|.*\.repo' | xargs dos2unix > /dev/null 2>&1

● 临时使用

npm --registry https://registry.npm.taobao.org install express

● 永久使用

npm config set registry https://registry.npm.taobao.org

● 查看各中间件版名:

redis:

redis-server -v

zookeeper:

echo stat|nc localhost 2181


 

● 清理iptables规则

iptables-restore < /etc/sysconfig/iptables


 

● docker save -o image.tar image

//image.tar(保存的镜像名称)image(要保存的镜像名称)

docker load --input image.tar

● docker tag image_id image_name:tag ##修改镜像名称

● ulimit -u 65535 #修改最大进程数

ulimit -HSn 64435 #修改进程打开最大文件数


 

● 数据库授权

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' identified by "password";


 

● Windows杀死进程

taskkill /pid 14820 -t -f

● SCP将远程主机文件拷贝到本地

scp root@ip:/data/update_kernel_418.tar.gz /data/

● 查看容器IP地址

docker inspect --format='{{.NetworkSettings.IPAddress}}' contain_id

查看容器运行状态 #返回容器name和运行状态(true、false)

docker inspect --format '{{.Name}} {{.State.Running}}' contain_id

● //手动修改mut值

//echo "1460" > /sys/class/net/eth0/mtu

● //获取系统时间戳

ctime=`date "+%Y-%m-%d %H:%M:%S"`

● //查看消耗内存最多的四个进程

ps auxw|head -1;ps auxw|sort -rn -k4|head -4

● npm install在哪个目录下执行就安装在这个目录的node_modules文件夹下。

● package.json定义了需要安装哪些依赖,在package.json所在的目录下执行npm install。

● 如果是npm instal -g,则是安装在全局的地方,所有node项目都可以使用这个module,安装路径可以通过npm config get prefix查看。


 

//机器重置后,lvm卷怎么重新激活

●lvscan

inactive '/dev/vgdata/lvdata' [<200.00 GiB] inherit

●vgchange -ay /dev/vgdata

1 logical volume(s) in volume group "vgdata" now active

●mount /dev/vgdata/lvdata /data/






 

相关推荐

  1. 命令简单shell语句

    2024-04-21 12:36:02       26 阅读
  2. 80个shell命令简单

    2024-04-21 12:36:02       37 阅读
  3. Redis命令指令、描述简单举例

    2024-04-21 12:36:02       34 阅读
  4. [日常使用] Shell命令

    2024-04-21 12:36:02       28 阅读
  5. 100个shell命令

    2024-04-21 12:36:02       19 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-21 12:36:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-21 12:36:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-21 12:36:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-21 12:36:02       18 阅读

热门阅读

  1. js html生成图片

    2024-04-21 12:36:02       19 阅读
  2. 《AI聊天类工具之七—— Grok》

    2024-04-21 12:36:02       15 阅读
  3. 使用Python制作读单词视频(含源码)

    2024-04-21 12:36:02       13 阅读
  4. unet改进笔记

    2024-04-21 12:36:02       18 阅读
  5. 命令模式:将请求封装为对象

    2024-04-21 12:36:02       35 阅读
  6. 设计模式-命令模式

    2024-04-21 12:36:02       16 阅读
  7. 数字化转型安全运维:构建稳健的网络安全防线

    2024-04-21 12:36:02       19 阅读
  8. 【二轮征稿】经济金融发展国际会议(ICEFD 2024)

    2024-04-21 12:36:02       15 阅读
  9. 内存段介绍

    2024-04-21 12:36:02       17 阅读
  10. 如何防止服务器被攻击

    2024-04-21 12:36:02       12 阅读
  11. K8s集群中关于容器的设置

    2024-04-21 12:36:02       26 阅读