技巧总结-2018-06

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了技巧总结-2018-06相关的知识,希望对你有一定的参考价值。

技巧总结-2018-06

2018.05


grep持续监控Log:

tail -f file | grep --line-buffered my_pattern

列表和deque的区别:

  • 根据index读list,时间复杂度为O(1)但deque是O(n)
  • 在两头插入数据,deque的时间复杂度为O(1), list为O(n)
  • deque是一个双向链表,所以操作头尾非常简单。
  • 随机往中间插入数据,deque与list的时间复杂度都是O(n)
    2018.04

MongoDB的聚合查询中,$substr只能匹配ASCII的数据,对于中文要使用$substrCP

Flask的上下文对象current_app只能在请求线程里存在,因此它的生命周期也是在应用上下文里,离开了应用上下文也就无法使用。


app = Flask(‘__name__‘)
print(current_app.name)

会报错:


RuntimeError: working outside of application context

此时可以手动创建应用上下文:


with app.app_context():
    print(current_app.name)

扩展AWS的磁盘空间:

技术图片

点击修改卷增加磁盘配额,SSH进入服务器,输入以下代码:

lsblk  #这条命令用来确定当前可用的磁盘空间小于磁盘配额

sudo growpart /dev/xvda 1

sudo resize2fs /dev/xvda1

再次执行df -h可以看到已经使用了新的空间

2018.03


在Docker查看正在运行的容器是通过什么命令启动的:


docker ps -a --no-trunc

在全新的Ubuntu中安装pip:


sudo apt-get update
sudo apt-get upgrade
sudo apt-get install python3-pip
sudo apt-get install build-essential libssl-dev libffi-dev python3-dev

tar压缩文件的时候排除特定文件和文件夹:


tar --exclude=‘./folder‘ --exclude=‘./upload/folder2‘ -zcvf /backup/filename.tgz .

2018.02


在MongoDB使用自带的mongodump备份数据的时候,如果数据库设置了密码,那么在指定mongodump的--password 密码参数的同时,还必须指定--authenticationDatabase admin

2018.01


使用grep持续监控Log:


tail -f file | grep --line-buffered my_pattern

使用rsync通过SSH从服务器拉取数据:


rsync -avzP ubuntu@xx.xxx.xx.xxx:Projects/sample.csv ~/sample.csv

如果有SSH Key的话,使用下面的命令:


rsync -avzP -e "ssh -i ~/sshkey.pem" ubuntu@xx.xxx.xx.xxx:Projects/sample.csv ~/sample.csv

在Ubuntu中修改时区:


sudo timedatectl set-timezone Asia/Shanghai

使用XPath获取名称包含特定字符的属性的属性值:


//span/img/@*[contains(name(), "src")]

AWS在一年免费期间内,换机房不用给钱。先在老的实例生成AMI,再把AMI复制到新的城市,再从新城市的AMI创建实例。然后把老城市的实例彻底终结,取消老城市和新城市的AMI。全程不收费。

在Python中执行Shell命令并获取返回结果:


import subprocess
shell_result = subprocess.check_output(‘ps -ef | grep 进程名 | grep -v grep‘, shell=True).decode().strip().split(‘
)

如果命令本身没有返回,则会抛出一个subprocess.CalledProcessError

在Shell中判断一个进程是否存在:


if ps -ef | grep 进程名 | grep -v grep > /dev/null
then
    echo "进程存在"
else
    echo "进程不存在"
fi

2017.12


firewalld对特定IP开放特定端口:


firewall-cmd --permanent --zone=public --add-rich-rule=‘rule family="ipv4" source address="特定IP" port protocol="tcp" port="特定端口" accept‘

生成文件树并过滤特定文件或文件夹:


tree -I ‘__pycache__|pyc|Logs‘

统计代码行数:


find . -name "*.py" | xargs wc -l

为pip设置代理:


pip3.6 --proxy http://代理IP:端口 install -r requirements.txt

为Git设置代理:


RUN git config --global http.proxy http://代理IP:端口
RUN git config --global http.sslverify "false"

为Ubuntu的apt-get设置代理:


vim /etc/apt/apt.conf.d/01turnkey

在里面插入一行:
Acquire::http::Proxy "http://your.proxy.here:port/";
保存以后,下一次执行apt-get命令就会使用代理了。

2017.11


修改Elasticsearch默认的数据文件地址到/mnt/es文件夹,需要首先创建这个文件夹,然后为elasticsearch这个用户添加这个文件夹的权限:


Chown -R elasticsearch:elasticsearch /mnt/es/

然后再修改elasticsearch的配置文件。

在postgres中,占位符是$1, $2而不是mysql中的?

2017.10


使用urlpare从URL中获取Host:


>>> from urllib.parse import urlparse
>>> url = ‘https://nanjirenlk.tmall.com/shop/view_shop.htm‘
>>> x = urlparse(url)>>> x.netloc‘nanjirenlk.tmall.com‘

解压tar.gz压缩文件:


tar zxvf 文件名

根据进程名字在Linux里杀进程。


ps -ef | grep "进程关键字" | grep -v grep | awk ‘{print $2}‘ | xargs kill -9

在Python 的try ... except Exception ...中显示tracebook:

import traceback
try:
    1 + ‘a‘
except Exception as e:
    tb = traceback.format_exc()
    print(tb)

输出如下:


Traceback (most recent call last):
  File "<stdin>", line 2, in <module>
TypeError: unsupported operand type(s) for +: ‘int‘ and ‘str‘

这个功能在多层try ... except Exception ... 嵌套的时候特别有用。

以上是关于技巧总结-2018-06的主要内容,如果未能解决你的问题,请参考以下文章

Android课程---Android Studio使用小技巧:提取方法代码片段

VS2015使用技巧 打开代码片段C#部分

26个jQuery代码片段使用技巧

extjs常用技巧

提效小技巧——记录那些不常用的代码片段

你可能不知道的JavaScript代码片段和技巧(下)