Ubuntu 18.04 下解决 shadowsocks 服务报错问题

1. 报错内容 启动时报错如下: Traceback (most recent call last): File "/usr/local/bin/sslocal", line 11, in sys.exit(main()) File "/usr/local/lib/python3.6/dist-packages/shadowsocks/local.py", line 39, in main config = shell.get_config(True) File "/usr/local/lib/python3.6/dist-packages/shadowsocks/shell.py", line 262, in get_config check_config(config, is_local) File "/usr/local/lib/python3.6/dist-packages/shadowsocks/shell.py", line 124, in check_config encrypt.try_cipher(config, config) File "/usr/local/lib/python3.6/dist-packages/shadowsocks/encrypt.py", line 44, in try_cipher Encryptor(key, method) File "/usr/local/lib/python3.6/dist-packages/shadowsocks/encrypt.py", line 83, in init random_string(self._method_info)) File "/usr/local/lib/python3.6/dist-packages/shadowsocks/encrypt.py", line 109, in get_cipher return m(method, key, iv, op) File "/usr/local/lib/python3.6/dist-packages/shadowsocks/crypto/openssl.py", line 76, in init load_openssl() File "/usr/local/lib/python3.6/dist-packages/shadowsocks/crypto/openssl.py", line 52, in load_openssl libcrypto.EVP_CIPHER_CTX_cleanup.argtypes = (c_void_p,) File "/usr/lib/python3.6/ctypes/init.py", line 361, in getattr func = self.getitem(name) File "/usr/lib/python3.6/ctypes/init.py", line 366, in getitem func = self._FuncPtr((name_or_ordinal, self))...
阅读全文

Windows下清理samba信息

前言:最近win7连接samba服务器时总是提示需要输入账号密码,但我记得账号密码并没有改变,可能是保存了之前的账号信息,接下来清理一波。 0x01 windows清除访问samba局域网密码缓存 1、打开cmd,输入control userpasswords2或者control keymgr.dll,然后【高级】/【密码管理】,删掉保存的该机器密码。 0x02 windows清除连接的linux的samba服务缓存 打开win的命令行。 输入net use,就会打印出当前缓存的连接上列表。 根据列表,一个个删除连接: net use 远程连接名称 /del;或者一次性全部删除:net use * /del。 0x03 windows上批处理建立、删除smb磁盘映射 以前每次将samba映射到windows的磁盘上时,都要手动敲命令,然后右键磁盘映射。这些都是可以通过net命令来完成。 建立磁盘映射: net use Z: \\192.168.1.7\ubuntu smbpassword /user:smbuser Z: 你要映射到windows的哪个磁盘 \192.168.1.7\ubuntu:你的samba路径 smbpassword:samba密码 smbuser:samba用户名 删除磁盘映射: net use * /del /y :所有映射到windows的磁盘盘符,也可以指定具体的如Z: 、Y: /y:如果不加这个,每次都会提示你是否删除磁盘映射 将两个命令分别保存到两个批处理文件里面,需要哪个时就点击哪个,十分方便快捷。
阅读全文

如何解压rpm包并重新打包

1、安装rpmrebuild和rpmbuild工具 # 安装rpmbuild工具套件 yum install rpm-build rpmrebuild工具可在以下链接中下载,一般下载最新版本 点击下载rpmrebuild源码包 2、配置rpm重编译目录 编辑 ~/.rpmmacros文件,在其中加入以下内容: %_topdir /root/rpmbuild 3、创建编译目录 mkdir -p /root/rpmbuild/{BUILDROOT,SPECS} # 解压rpmrebuild源码包,我这里下载的是2.15版本 cd /root/rpmbuild tar -zxvf rpmrebuild-2.15.tar.gz 4、安装需要重打包的rpm包 这里以net-tools-xx.xx.rpm包为例,安装包是从ISO中取出来的 rpm -ivh net-tools-xx.xx.rpm 5、生成rpm所需要的编译脚本net-tools.spec # 第4步中已经安装了net-tools安装包,我们可以通过以下命令查看安装的软件包 rpm -qa | grep net-tools # 获取到的是不带版本和发行版的包名为net-tools来重新生成 cd /root/rpmbuild ./rpmrebuild.sh -s SPEC/net-tools.spec net-tools 查看net-tools.spec文件内容如下,这里我只展示关键部分: # rpmrebuild autogenerated specfile %define defaultbuildroot / AutoProv: no %undefine __find_provides AutoReq: no %undefine __find_requires # Do not try autogenerate prereq/conflicts/obsoletes and check files %undefine __check_files %undefine __find_prereq %undefine __find_conflicts %undefine __find_obsoletes # Be sure buildpolicy set to do nothing %define __spec_install_post %{nil} # Something that need for rpm-4.1 %define _missing_doc_files_terminate_build 0 #dummy #dummy...
阅读全文

mysql查看数据库性能常用命令

摘自: http://blog.csdn.net/iquicksandi/article/details/7970706 http://www.cnblogs.com/w2154/p/4691015.html 网上有很多的文章教怎么配置MySQL服务器,但考虑到服务器硬件配置的不同,具体应用的差别,那些文章的做法只能作为初步设置参考,我们需要根据自己的情况进行配置优化,好的做法是MySQL服务器稳定运行了一段时间后运行,根据服务器的”状态”进行优化。 mysql> show global status; # 可以列出MySQL服务器运行各种状态值,另外,查询MySQL服务器配置信息语句: mysql> show variables; ``` #### 一、慢查询 ```shell   mysql> show variables like '%slow%';   +------------------+-------+   | Variable_name | Value |   +------------------+-------+   | log_slow_queries | ON |   | slow_launch_time | 2 |   +------------------+-------+   mysql> show global status like '%slow%';   +---------------------+-------+   | Variable_name | Value |   +---------------------+-------+   | Slow_launch_threads | 0 |   | Slow_queries | 4148 |   +---------------------+-------+   配置中打开了记录慢查询,执行时间超过2秒的即为慢查询,系统显示有4148个慢查询,你可以分析慢查询日志,找出有问题的SQL语句,慢查询时间不宜设置过长,否则意义不大,最好在5秒以内,如果你需要微秒级别的慢查询,可以考虑给MySQL打补丁: http://www.percona.com/docs/wiki/release:start,记得找对应的版本。 打开慢查询日志可能会对系统性能有一点点影响,如果你的MySQL是主-从结构,可以考虑打开其中一台从服务器的慢查询日志,这样既可以监控慢查询,对系统性能影响又小。 二、连接数   经常会遇见”MySQL: ERROR 1040: Too many connections”的情况,一种是访问量确实很高,MySQL服务器抗不住,这个时候就要考虑增加从服务器分散读压力,另外一种情况是MySQL配置文件中max_connections值过小: mysql> show variables like 'max_connections'; +-----------------+-------+ | Variable_name | Value | +-----------------+-------+ | max_connections | 256 | +-----------------+-------+   这台MySQL服务器最大连接数是256,然后查询一下服务器响应的最大连接数: mysql> show global status like ‘Max_used_connections’; MySQL服务器过去的最大连接数是245,没有达到服务器连接数上限256,应该没有出现1040错误,比较理想的设置是:...
阅读全文

MySQL占用磁盘I/O问题排查

前言:最近查一个磁盘I/O高的问题,涉及到了innodb_flush_log_at_trx_commit 和 sync_binlog 是 MySQL 的两个配置参数,前者是 InnoDB 引擎特有的。之所以把这两个参数放在一起讨论,是因为在实际应用中,它们的配置对于 MySQL 的性能有很大影响。 innodb_flush_log_at_trx_commit 简而言之,innodb_flush_log_at_trx_commit 参数指定了 InnoDB 在事务提交后的日志写入频率。这么说其实并不严谨,且看其不同取值的意义和表现。 当 innodb_flush_log_at_trx_commit 取值为 0 的时候,log buffer 会 每秒写入到日志文件并刷写(flush)到磁盘。但每次事务提交不会有任何影响,也就是 log buffer 的刷写操作和事务提交操作没有关系。在这种情况下,MySQL性能最好,但如果 mysqld 进程崩溃,通常会导致最后 1s 的日志丢失。 当取值为 1 时,每次事务提交时,log buffer 会被写入到日志文件并刷写到磁盘。这也是默认值。这是最安全的配置,但由于每次事务都需要进行磁盘I/O,所以也最慢。 当取值为 2 时,每次事务提交会写入日志文件,但并不会立即刷写到磁盘,日志文件会每秒刷写一次到磁盘。这时如果 mysqld 进程崩溃,由于日志已经写入到系统缓存,所以并不会丢失数据;在操作系统崩溃的情况下,通常会导致最后 1s 的日志丢失。 上面说到的「最后 1s」并不是绝对的,有的时候会丢失更多数据。有时候由于调度的问题,每秒刷写(once-per-second flushing)并不能保证 100% 执行。对于一些数据一致性和完整性要求不高的应用,配置为 2 就足够了;如果为了最高性能,可以设置为 0。有些应用,如支付服务,对一致性和完整性要求很高,所以即使最慢,也最好设置为 1. sync_binlog sync_binlog 是 MySQL 的二进制日志(binary log)同步到磁盘的频率。MySQL server 在 binary log 每写入 sync_binlog 次后,刷写到磁盘。 如果 autocommit 开启,每个语句都写一次 binary log,否则每次事务写一次。默认值是 0,不主动同步,而依赖操作系统本身不定期把文件内容 flush 到磁盘。设为 1 最安全,在每个语句或事务后同步一次 binary log,即使在崩溃时也最多丢失一个语句或事务的日志,但因此也最慢。 大多数情况下,对数据的一致性并没有很严格的要求,所以并不会把 sync_binlog 配置成 1. 为了追求高并发,提升性能,可以设置为 100 或直接用 0. 而和 innodb_flush_log_at_trx_commit 一样,对于支付服务这样的应用,还是比较推荐 sync_binlog = 1. 查看配置参数 使用iostat -dxm 1命令和iotop命令查看磁盘的占用情况,配置修改后: mysql> show variables like '%sync_bin%'; +---------------+-------+...
阅读全文