1 阻止服务启动
- 创建一个空文件去阻止服务启动
sudo touch /etc/cloud/cloud-init.disabled
2 卸载
- 禁用除开“None”之外的全部服务
dpkg-reconfigure cloud-init
- 卸载并删除相关文件夹
sudo apt-get purge cloud-init
sudo rm -rf /etc/cloud/ && sudo rm -rf /var/lib/cloud/
- 重启
sudo reboot
sudo touch /etc/cloud/cloud-init.disabled
dpkg-reconfigure cloud-init
sudo apt-get purge cloud-init
sudo rm -rf /etc/cloud/ && sudo rm -rf /var/lib/cloud/
sudo reboot
GPL和AGPLv3的区别
GPL:GNU通用公共许可证(GNU General Public License) AGPL:The GNU Affero General Public License
GPL v3协议,意味着修改和使用其代码都需要开源,但是这是建立在软件分发的基础上,如果使用代码作为服务提供,而不分发软件,则不需要开源。这实际上是GPL协议本身的缺陷。
AGPL v3协议,也就是说,除非获得商业授权,否则无论以何种方式修改或者使用代码,都需要开源。
SSPL 和 AGPL 协议有什么区别?
SSPL:The Server Side Public License (SSPL) is a proprietary/source-available software license developed by MongoDB Inc., and introduced in 2018.[wikipedia] SSPL 构建于 AGPL 的精神之上,但明确了将开源软件作为服务提供的条件。 SSPL 保留了开源社区在 AGPL 下使用 MongoDB 所有拥有的相同权利:使用、审查、修改和重新发布软件的自由。
唯一实质性的变化,就是加了一个明确的条件,即任何试图将 MongoDB 作为服务加以利用的组织,都必须开放用于提供,但 SSPL 不属于开源协议。
# -*- coding: utf-8 -*-
# tcp mapping
import sys
import socket
import logging
import threading
# 端口映射配置信息
CFG_REMOTE_IP = '127.0.0.1'
CFG_REMOTE_PORT = 23
CFG_LOCAL_IP = '0.0.0.0'
CFG_LOCAL_PORT = 1023
# 接收数据缓存大小
PKT_BUFF_SIZE = 2048
logger = logging.getLogger("Proxy Logging")
formatter = logging.Formatter('%(name)-12s %(asctime)s %(levelname)-8s %(lineno)-4d %(message)s',
'%Y %b %d %a %H:%M:%S', )
stream_handler = logging.StreamHandler(sys.stderr)
stream_handler.setFormatter(formatter)
logger.addHandler(stream_handler)
logger.setLevel(logging.DEBUG)
# 单向流数据传递
def tcp_mapping_worker(conn_receiver, conn_sender):
while True:
try:
data = conn_receiver.recv(PKT_BUFF_SIZE)
except Exception:
logger.debug('Connection closed.')
break
if not data:
logger.info('No more data is received.')
break
try:
conn_sender.sendall(data)
except Exception:
logger.error('Failed sending data.')
break
# logger.info('Mapping data > %s ' % repr(data))
logger.info(
'Mapping > %s -> %s > %d bytes.' % (conn_receiver.getpeername(), conn_sender.getpeername(), len(data)))
conn_receiver.close()
conn_sender.close()
return
# 端口映射请求处理
def tcp_mapping_request(local_conn, remote_ip, remote_port):
remote_conn = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
try:
remote_conn.connect((remote_ip, remote_port))
except Exception:
local_conn.close()
logger.error('Unable to connect to the remote server.')
return
threading.Thread(target=tcp_mapping_worker, args=(local_conn, remote_conn)).start()
threading.Thread(target=tcp_mapping_worker, args=(remote_conn, local_conn)).start()
return
# 端口映射函数
def tcp_mapping(remote_ip, remote_port, local_ip, local_port):
local_server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
local_server.bind((local_ip, local_port))
local_server.listen(5)
logger.debug('Starting mapping service on ' + local_ip + ':' + str(local_port) + ' ...')
while True:
try:
(local_conn, local_addr) = local_server.accept()
except KeyboardInterrupt as Exception:
local_server.close()
logger.debug('Stop mapping service.')
break
threading.Thread(target=tcp_mapping_request, args=(local_conn, remote_ip, remote_port)).start()
logger.debug('Receive mapping request from %s:%d.' % local_addr)
return
# 主函数
if __name__ == '__main__':
tcp_mapping(CFG_REMOTE_IP, CFG_REMOTE_PORT, CFG_LOCAL_IP, CFG_LOCAL_PORT)
5500 V3 默认有以下硬盘:
CTE0 SSD 366GB*25
DAE0 SSD 361GB*25
DAE1 SSD 361GB*25
DAE2 SSD SED 366GB*25
DAE3 SAS 1.78TB*25
DAE4 NL-SAS 1.78TB*24
DAE5 NL-SAS SED 1.78TB*24
DAE6 NL-SAS 1.78TB*75
DAE7 NL-SAS SED 1.78TB*75
DAE8 NL-SAS 1.78TB*75
DAE9 SAS SED 1.79TB*24
桌面版安装后约占 7GB,服务器版最简单的安装后约2.2GB。装服务器版用8GB的SSD就够用了。
执行下面的代码便可:
echo 'disable_camera_led=1' >> /boot/config.txt
统计文件夹下php文件的代码行数:
find . -name "*.php" |xargs cat|grep -v -e ^$ -e ^\s*\/\/.*$|wc -l
统计php、js、html文件的代码行数:
find ./ -regex ".*\.php\|.*\.js\|.*\.html" | xargs cat|grep -v -e ^$ -e ^\s*\/\/.*$|wc -l
在Ubuntu20.04中已经不使用/etc/networks/interface来配置网络了,而是使用netplan配置网络:
# cat /etc/netplan/00-installer-config.yaml
这是DHCP配置IP:
# This is the network config written by 'subiquity'
network:
ethernets:
ens18:
dhcp4: true
version: 2
这是固定IP:
network:
ethernets:
ens18:
addresses: [172.18.176.239/24]
dhcp4: no
optional: true
gateway4: 172.18.176.254
nameservers:
addresses: [114.114.114.114]
version: 2
sed -i "s/data.status !== 'Active'/false/g" /usr/share/javascript/proxmox-widget-toolkit/proxmoxlib.js
在命令行中执行代码。然后重启
systemctl restart pveproxy
ubuntu 18.04默认的Python版本是2的,要改成3的。
可以变更快捷方式,也可以增加alias,还可以用下面的方式去更改:
update-alternatives --install /usr/bin/python python /usr/bin/python3 1
pip也一起修改一下:
update-alternatives --install /usr/bin/pip pip /usr/bin/pip3 1