二进制安全

密码学 二进制安全是指,在传输数据时,保证二进制数据的信息安全,也就是不被篡改、破译等,如果被攻击,能够及时检测出来。 二进制安全包含了密码学的一些东西,比如加解密、签名等。 数据存取 二进制安全功能(binary-safe function)是指在一个二进制文件上所执行的不更改文件内容的功能或者操作。这能够保证文件不会因为某些操作而遭到损坏。二进制数据是按照一串0和1的形式编码的。而绝大多数的程序会给某些特殊的比特串赋予不同的格式代码,所以当用户使用一个程序读取一个二进制文件时,该文件会被按照这个程序的规则进行解释。如果这个程序所使用的格式编码和文件被写入的格式编码一致,那么这个文件可以被正常读取,否则该文件的格式代码之中会被附加一些无意义的符号,也可能会导致文件损坏。如果最严重的情况发生,这样的操作会因为损坏导致你的数据永久丢失。所以你应该将重要的文件保存在只读性的存储介质上,例如光盘。 ...

2021-12-07 · 2 min · 912 words · Superb

Windows的UEFI/Legacy

Windows引导模式,BIOS(Leagacy)+MBR 和 UEFI+GPT UEFI-BIOS启动区别 UEFI全称“统一可扩展固件接口”(Unified Extensible Firmware Interface) 知识点: UEFI必须使用GPT磁盘分区,必须使用64位操作系统 Leagacy(bios)只能使用MBR磁盘分区 GPT对分区数量无限制,Windows最大支持128GPT分区 GPT分区无法使用Leagacy引导启动,只能使用UEFI GPT分区自纠错能力更强,稍稳定于MBR CSM兼容启动模式,是UEFI和传统BIOS两者共存模式,既能用传统BIOS引导模式,也能用新式UEFI启动电脑系统。 ...

2021-12-07 · 1 min · 273 words · Superb

DATABASE笔记

内存数据库 Redis Memercache 常规数据库 Mysql Oracle Mogodb Sqlserver 对文件,图片,二进制数据不存储在数据库: 1.数据库备份变大,耗时长。 2.大字段加重数据库负担,拖慢数据库,不适合大并发。 3.增加复杂度。对文件的访问需要穿越你的应用层和数据库层。 ...

2021-12-07 · 5 min · 2401 words · Superb

CMD控制台颜色

设置默认的控制台前景和背景颜色。 COLOR [attr] attr 指定控制台输出的颜色属性。 颜色属性由两个十六进制数字指定 – 第一个 对应于背景,第二个对应于前景。每个数字 可以为以下任何值: ...

2021-12-07 · 1 min · 188 words · Superb

Windows代码页/内码表编号

早期IBM和微软内部使用特别数字来标记这些编码,其实大多的这些编码已经有自己的名称了。虽然图形操作系统可以支持很多编码,很多微软程序还使用这些数字来点名某编码 ...

2021-12-07 · 2 min · 643 words · Superb

etcd集群排错

解决方法: 清空原数据目录 该节点已经被引导,可能是因为之前这个节点已经加入过集群了,但配置失败,在启动参数那里设置的是new,所以需要将new修改为existing。编辑etcd.service 文件,–initial-cluster-state existing更新 如果初始化集群有多个节点,确保所有节点数据目录清空,集群改为new,依次重启每个节点服务,直到所有服务正常。 ...

2021-12-07 · 1 min · 239 words · Superb

不同Linux发行版的网络配置文件

netplan、networkctl、nmcli 以及 systemd-networkd 是Linux系统中用于配置和管理网络的不同工具和服务,他们各自有不同的作用和使用情景。 netplan: 目的:netplan是一个基于YAML的网络配置抽象层,用于统一不同的网络配置服务(如NetworkManager和systemd-networkd)的配置方式。 配置文件:通常位于/etc/netplan/目录下,使用YAML格式。 工作方式:用户编辑YAML文件,netplan将这些配置转换为底层网络管理器(如NetworkManager或systemd-networkd)可以理解的配置。 适用环境:主要用于Ubuntu 17.10及以后版本。 networkctl: 目的:是systemd-networkd的命令行前端,用于查询和控制systemd-networkd管理的网络状态。 命令:可以查看网络接口的状态、配置等信息。 工作方式:作为systemd-networkd的辅助工具,直接与systemd-networkd的状态和配置进行交互。 适用环境:适合于使用systemd-networkd作为网络管理器的系统。 nmcli: 目的:是NetworkManager的命令行界面,用于配置和管理NetworkManager服务。 命令:可以进行网络连接的添加、修改、删除、激活和非激活等操作。 工作方式:直接与NetworkManager的守护进程进行交互,不依赖于其他配置文件,虽然也可以管理和查看/etc/NetworkManager/目录下的配置。 适用环境:广泛用于各种Linux发行版,尤其适合桌面环境和需要频繁更改网络设置的场景。 systemd-networkd: 目的:是一个系统服务,用于配置网络设备和连接。 配置文件:通常位于/etc/systemd/network/目录下。 工作方式:在系统启动时(或服务启动时)应用配置,管理网络接口。 适用环境:适合于服务器或容器环境,以及对于稳定性和轻量级配置有较高要求的场景。 systemctl 命令的区别 systemctl restart systemd-networkd:重启systemd-networkd服务,会重新应用/etc/systemd/network/目录下的配置。 systemctl restart networking:这通常是基于ifupdown的旧式网络管理脚本在Debian和Ubuntu上的服务名称,用于重启传统的网络服务。 systemctl restart network:在基于Red Hat的系统上,如CentOS和Fedora,这个命令会重启传统的网络服务(在这些系统中,System V之前的/etc/init.d/network脚本或与其相对应的systemd服务)。 他们之间的关系 netplan 可以配置以 systemd-networkd 或者 NetworkManager 为后端的网络设置。 networkctl 是 systemd-networkd 的配套工具,用于查看由 systemd-networkd 管理的网络接口的状态。 nmcli 是 NetworkManager 的命令行工具,用于配置和控制 NetworkManager。 systemd-networkd、networking、和 network 是Linux系统中可能的不同网络服务,具体使用哪一个取决于系统配置和发行版。通过systemctl重启这些服务可以应用新的网络配置或者重置网络连接。 Red Hat Linux / CentOS 系列网络配置文件路径: - /etc/sysconfig/network-scripts/ifcfg-ethX # IP地址,子网掩码等配置文件<br> - /etc/sysconfig/network-scripts/ifcfg-lo # 回环网卡配置<br> - /etc/sysconfig/network # 主机名和网关配置文件<br> - /etc/resolv.conf # DNS配置文件<br> - /etc/hosts # 主机和IP绑定信息<br> suse Linux 网络配置文件路径: - /etc/sysconfig/network/ifcfg-eth-id-HWaddr # IP地址,子网掩码等配置文件<br> - /etc/HOSTNAME # 全局主机名配置<br> - /etc/resolv.conf # DNS配置文件<br> - /etc/sysconfig/network/routes # 网关配置文件<br> - /etc/hosts # 主机和IP绑定信息<br> Debian / Ubuntu Linux 网络配置文件路径: ubuntu从17.10开始,已放弃在/etc/network/interfaces里固定IP的配置,即使配置也不会生效,而是改成netplan方式 ,配置写在/etc/netplan/的yaml文件里 ...

2021-12-07 · 4 min · 1857 words · Superb

logrotate日志切割工具

logrotate是个十分有用的工具,它可以自动对日志进行截断(或轮循)、压缩以及删除旧的日志文件。例如,你可以设置logrotate,让/var/log/foo日志文件每30天轮循,并删除超过6个月的日志。配置完后,logrotate的运作完全自动化,不必进行任何进一步的人为干预 ...

2021-12-07 · 2 min · 713 words · Superb

ffmpeg常用命令

使用intel h264_qsv 编码器转码 ffmpeg -i x.mp4 -c:v h264_qsv x.mkv 转换容器格式(transmuxing)指的是,将视频文件从一种容器转到另一种容器 ffmpeg -i x.mp4 -c copy x.avi 只转容器,内部的编码格式不变,使用-c copy指定直接拷贝,不经过转码,这样比较快 ...

2021-12-07 · 1 min · 427 words · Superb

k8s笔记

kubernetes组件: etcd 一个高可用的K/V键值对存储和服务发现系统 flannel 实现夸主机的容器网络的通信 kube-apiserver 提供kubernetes集群的API调用 kube-controller-manager 确保集群服务,控制器群 kube-scheduler 调度容器,分配到Node。调度器,大大缓解了APISERVER入口压力 kubelet 在Node节点上按照配置文件中定义的容器规格启动容器 kube-proxy 提供网络代理服务 master etcd kube-apiserver kube-controller-manage kube-scheduler node kube-proxy kubelet 节点加入集群 #重新生成新的token kubeadm token create kubeadm token list #获取ca证书sha256编码hash值 openssl x509 -pubkey -in /etc/kubernetes/pki/ca.crt | openssl rsa -pubin -outform der 2>/dev/null | openssl dgst -sha256 -hex | sed 's/^.* //' #节点加入集群 kubeadm reset kubeadm join 192.168.38.11:6443 --token c9afga.w3fue0yh3gzxczic --discovery-token-ca-cert-hash sha256:8b79b6461e58c07333cb2851fe74fd4374af8bbbe0bf7e040b415b86ad4fb89d #查看节点 kubectl get nodes 新加入master节点 kubeadm join 192.168.0.200:6443 --token 9vr73a.a8uxyaju799qwdjv --discovery-token-ca-cert-hash sha256:7c2e69131a36ae2a042a339b33381c6d0d43887e2de83720eff5359e26aec866 --control-plane --certificate-key f8902e114ef118304e561c3ecd4d0b543adc226b7a07f675f56564185ffe0c07 #- 这个 --control-plane 命令通知 kubeadm join 创建一个新的控制平面。 #- --certificate-key ... 将导致从集群中的 kubeadm-certs 秘钥下载控制平面证书并使用给定的密钥进行解密。 监控工具 ctop ...

2021-12-07 · 2 min · 931 words · Superb