常用命令
查看linux中某个端口(port)是否被占用
- 使用lsof
lsof -i:80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 3574 root 6u IPv4 43144 0t0 TCP *:http (LISTEN)
nginx 3575 nobody 6u IPv4 43144 0t0 TCP *:http (LISTEN)
java 15723 root 398u IPv6 6138432 0t0 TCP gs.meizu.com:48906->yard.meizu.com:http (ESTABLISHED)
java 28892 root 88u IPv6 5558629 0t0 TCP gs.meizu.com:46250->bogon:http (CLOSE_WAIT)
java 28892 root 91u IPv6 5554570 0t0 TCP gs.meizu.com:46198->bogon:http (CLOSE_WAIT)
java 28892 root 95u IPv6 5555697 0t0 TCP gs.meizu.com:46200->bogon:http (CLOSE_WAIT)
java 28892 root 97u IPv6 5551621 0t0 TCP gs.meizu.com:46204->bogon:http (CLOSE_WAIT)
- 使用netstat
netstat -anp|grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 3574/nginx
tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN 8580/cupsd
tcp 0 0 172.16.42.71:80 172.16.42.71:46752 TIME_WAIT -
tcp 0 0 172.16.42.71:80 172.16.42.71:46874 TIME_WAIT -
tcp 0 0 172.16.42.71:38052 216.58.200.14:443 TIME_WAIT -
tcp 0 0 172.16.42.71:51940 183.6.231.233:80 ESTABLISHED 12970/firefox
Server
远程登录命令
SSH
ssh user@host
SCP
命令格式:
scp [参数] [原路径] [目标路径]
命令参数:
-1 强制scp命令使用协议ssh1
-2 强制scp命令使用协议ssh2
-4 强制scp命令只使用IPv4寻址
-6 强制scp命令只使用IPv6寻址
-B 使用批处理模式(传输过程中不询问传输口令或短语)
-C 允许压缩。(将-C标志传递给ssh,从而打开压缩功能)
-p 留原文件的修改时间,访问时间和访问权限。
-q 不显示传输进度条。
-r 递归复制整个目录。
-v 详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。
-c cipher 以cipher将数据传输进行加密,这个选项将直接传递给ssh。
-F ssh_config 指定一个替代的ssh配置文件,此参数直接传递给ssh。
-i identity_file 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。
-l limit 限定用户所能使用的带宽,以Kbit/s为单位。
-o ssh_option 如果习惯于使用ssh_config(5)中的参数传递方式,
-P port 注意是大写的P, port是指定数据传输用到的端口号
-S program 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。
使用说明
从本地服务器复制到远程服务器
- 复制文件:
$scp local_file remote_username@remote_ip:remote_folder
$scp local_file remote_username@remote_ip:remote_file
$scp local_file remote_ip:remote_folder
$scp local_file remote_ip:remote_file
指定了用户名,命令执行后需要输入用户密码;如果不指定用户名,命令执行后需要输入用户名和密码;
- 复制目录:
$scp -r local_folder remote_username@remote_ip:remote_folder
$scp -r local_folder remote_ip:remote_folder
第1个指定了用户名,命令执行后需要输入用户密码; 第2个没有指定用户名,命令执行后需要输入用户名和密码;
NOTE: 从远程复制到本地的scp命令与上面的命令一样,只要将从本地复制到远程的命令后面2个参数互换顺序就行了
使用示例
实例1:从远处复制文件到本地目录
$scp root@10.6.159.147:/opt/soft/demo.tar /opt/soft/
说明: 从10.6.159.147机器上的/opt/soft/的目录中下载demo.tar 文件到本地/opt/soft/目录中
实例2:从远处复制到本地
$scp -r root@10.6.159.147:/opt/soft/test /opt/soft/
说明: 从10.6.159.147机器上的/opt/soft/中下载test目录到本地的/opt/soft/目录来。
实例3:上传本地文件到远程机器指定目录
$scp /opt/soft/demo.tar root@10.6.159.147:/opt/soft/scptest
说明: 复制本地opt/soft/目录下的文件demo.tar 到远程机器10.6.159.147的opt/soft/scptest目录
实例4:上传本地目录到远程机器指定目录
$scp -r /opt/soft/test root@10.6.159.147:/opt/soft/scptest
说明: 上传本地目录 /opt/soft/test到远程机器10.6.159.147上/opt/soft/scptest的目录中
参考资料
zip
zip -q -r html.zip /home/html
chown
sudo chown -R group:user dir/
持续集成工具
MAVEN
// 跳过测试
mvn clean package -Dmaven.test.skip=true
// mvn jetty run
mvn jetty:run -Djetty.port=80
参考资料
中间件
NGINX
Nginx Ubuntu 安装
这里根据官网的步骤总结出来
下载nginx_signing.key
wget https://nginx.org/keys/nginx_signing.key
将nginx_signing.key添加到apt程序中
sudo apt-key add nginx_signing.key
在/etc/apt/sources.list
尾部添加下面的代码
deb http://nginx.org/packages/ubuntu/ xenial nginx
deb-src http://nginx.org/packages/ubuntu/ xenial nginx
上面的xenial是nginx在Ubuntu平台下发布版本的代码名称,也就是说不同版本的Ubuntu代码名称是不一样的,下面列举了各个Ubuntu版本的代码名称,具体详见
更新源并安装nginx
apt-get update
apt-get install nginx
NOTE: 如果以前安装nginx失败一定要完全卸载后在重新安装,不然会出现很多错误,nginx卸载方法如下
- 删除nginx,–purge包括配置文件
sudo apt-get --purge remove nginx
- 自动移除全部不使用的软件包
sudo apt-get autoremove
- 罗列出与nginx相关的软件
dpkg --get-selections|grep nginx
执行结果如下:unbutu16.04
nginx install
nginx-common deinstall
- 删除查询出与nginx有关的软件
sudo apt-get --purge remove nginx
sudo apt-get --purge remove nginx-common
- 查看nginx正在运行的进程,如果有就kill掉
ps -ef |grep nginx
结果如下:
root 5309 2614 0 17:03 ? 00:00:00 nginx: master process nginx
nginx 5310 5309 0 17:03 ? 00:00:00 nginx: worker process
- kill nginx进程
sudo kill -9 5309 5310
- 查看nginx配置
sudo nginx -t
结果如下:
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
参考资料
Nginx CentoS
Unbutu nginx 库支持
(1)PCRE库
PCRE库支持正则表达式。如果我们在配置文件nginx.conf中使用了正则表达式,那么在编译Nginx时就必须把PCRE库编译进Nginx,因为Nginx的HTTP模块需要靠它来解析正则表达式。另外,pcre-devel是使用PCRE做二次开发时所需要的开发库,包括头文件等,这也是编译Nginx所必须使用的。可以这样安装:
sudo apt-get install libpcre3 libpcre3-dev
(2)zlib库 zlib库用于对HTTP包的内容做gzip格式的压缩,如果我们在nginx.conf中配置了gzip on,并指定对于某些类型(content-type)的HTTP响应使用gzip来进行压缩以减少网络传输量,则在编译时就必须把zlib编译进Nginx。zlib-devel是二次开发所需要的库。可以这样安装:
sudo apt-get install zlib1g-dev
(3)OpenSSL库 如果服务器不只是要支持HTTP,还需要在更安全的SSL协议上传输HTTP,那么需要拥有OpenSSL。另外,如果我们想使用MD5、SHA1等散列函数,那么也需要安装它。可以这样安装:
sudo apt-get install openssl libssl-dev
- 查看端口监听进程
sudo su
netstat -ntpl
MySql
- 检查mysql本地是否安装
shell
sudo netstat -tap | grep mysql
- 安装mysql
sudo apt-get install mysql-server mysql-client
参考资料
Redis
wget http://download.redis.io/redis-stable.tar.gz
tar xvzf redis-stable.tar.gz
cd redis-stable
sudo make install //将redis安装到usr目录
Zookeeper
TomCat
Solr
Solr Cloud
启动solr Cloud
./bin/solr start -e cloud -z localhost:2181/galaxy2/solr -noprompt
上传一个配置目录
./server/scripts/cloud-scripts/zkcli.sh -zkhost 127.0.0.1:9983 \
-cmd upconfig -confname my_new_config -con-fdir
server/solr/configsets/basic_configs/conf
将一个集合连接到一个配置集
./server/scripts/cloud-scripts/zkcli.sh -zkhost 127.0.0.1:9983 \
-cmd linkconfig -collection gettingstarted -confname my_new_config
正则表达式
NPM
阿里云安装
- java
export MAVEN_HOME=/data/maven
export JAVA_HOME=/data/jdk
export JRE_HOME=$JAVA_HOME/jre
export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib:$CLASSPATH
export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$MAVEN_HOME/bin:$PATH
- 安装maven
- zookeeper
阿里域名解析服务
七牛对象存储
-
CND加速