CMPP SMS
2022-05-13
中国移动 CMPP 协议中的 UDH 头设计源自 SMPP 协议,SMPP 协议又是参考的 GSM 短信服务的相关标准。
- TP_UDHI 字段,1 bit,对应 GSM 协议中的 UDHI,表示短信中是否包含 UDH。
UDH
UDH,User Data Header,定义在 GSM 03.40 / 3GPP 23.040 中。
UDH 是短信中可能包含的一个二进制头部,对短信服务进行拓展。
可以实现以下功能:
- 长短信(级联短信):切割成多条,需要通过 UDH 中的总条数和序号来组装。
- EMS,增强型消息服务,支持颜色,文件格式,图片,动画,音乐
- MMS,彩信
- 本地语言转换表(Nation Language Shift Table):在 GSM-7 的框架上支持其他国家的语言。
概念:
- TP(Transfer Layer Protocol,传输层协议)
- TP-UD(User Data,用户数据),就是短信的正文部分
- 如果存在 UDH,那就在 TP-UD 的开头
- TP-UDHI(User Data Header Indicator,用户数据头指示器)
- 消息的第六 bit,表示短信中是否存在 UDH
UDHL:UDH Length,UDH 的第一字节,表示 UDH 的长度。
UDH 剩余部分是若干标签 + 长度 + 值的组合。其中标签又叫做 IEI(Information-Element-Identifier,信息元素标识符),占一字节。
例如:05 00 03 5F 03 01
- 第一字节 05,表示后面还有 5 Byte 是 UDH
- 第二字节 00,按照下面的 IEI 表,表示级联短信
- 第三字节 03,表示 IEI Length,也就是说这个 IEI 还有 3 Byte
- 第四字节 5F,按照级联短信的设计,这个 Byte 是一个随机 int8,避免不同批次短信搞混
- 第五字节 03,按照级联短信的设计,这个 Byte 表示总短信长度
- 第六字节 01,按照级联短信的设计,这个 Byte 表示当前短信在这一批次短信中的序号
重点:如果短信采用 GSM-7 编码,则需要对齐到 7 bit,也就是说真正需要的 bit 数是 math.ceil(6 * 8 / 7) * 7
上面这个例子,8 bit _ 6 = 48 bit,需要增加 1 bit,对齐成 7 bit _ 7 = 49 bit。
UDH Information Elements
IEI (hex) |
Meaning |
Classification |
Length |
May repeat |
00 |
Concatenated short messages, 8-bit reference number |
SMS Control |
3 |
no |
01 |
Special SMS Message Indication |
SMS Control |
2 |
yes |
02 |
Reserved |
N/A |
N/A |
yes |
03 |
Not used to avoid misinterpretation as <LF> character |
N/A |
N/A |
yes |
04 |
Application port addressing scheme, 8 bit address |
SMS Control |
2 |
no |
05 |
Application port addressing scheme, 16 bit address |
SMS Control |
4 |
no |
06 |
SMSC Control Parameters |
SMS Control |
1 |
no |
07 |
UDH Source Indicator |
SMS Control |
1 |
yes |
08 |
Concatenated short message, 16-bit reference number |
SMS Control |
4 |
no |
09 |
Wireless Control Message Protocol |
SMS Control |
1-255 |
yes |
0A |
Text Formatting |
EMS Control |
3-4 |
yes |
0B |
Predefined Sound |
EMS Content |
2 |
yes |
0C |
User Defined Sound (iMelody max 128 bytes) |
EMS Content |
2-129 |
yes |
0D |
Predefined Animation |
EMS Content |
2 |
yes |
0E |
Large Animation (1616 times 4 = 324 =128 bytes) |
EMS Content |
129 |
yes |
0F |
Small Animation (88 times 4 = 84 =32 bytes) |
EMS Content |
33 |
yes |
10 |
Large Picture (32*32 = 128 bytes) |
EMS Content |
129 |
yes |
11 |
Small Picture (16*16 = 32 bytes) |
EMS Content |
33 |
yes |
12 |
Variable Picture |
EMS Content |
4-255 |
yes |
13 |
User prompt indicator |
EMS Control |
1 |
yes |
14 |
Extended Object |
EMS Content |
7-255 |
yes |
15 |
Reused Extended Object |
EMS Control |
3 |
yes |
16 |
Compression Control |
EMS Control |
3-255 |
no |
17 |
Object Distribution Indicator |
EMS Control |
2 |
yes |
18 |
Standard WVG object |
EMS Content |
1-255 |
yes |
19 |
Character Size WVG object |
EMS Content |
1-255 |
yes |
1A |
Extended Object Data Request Command |
EMS Control |
0-255 |
no |
1B |
Reserved for future EMS features |
N/A |
0-255 |
yes |
1C |
Reserved for future EMS features |
N/A |
0-255 |
yes |
1D |
Reserved for future EMS features |
N/A |
0-255 |
yes |
1E |
Reserved for future EMS features |
N/A |
0-255 |
yes |
1F |
Reserved for future EMS features |
N/A |
0-255 |
yes |
20 |
RFC 822 E-Mail Header |
SMS Control |
1 |
no |
21 |
Hyperlink format element |
SMS Control |
0-255 |
yes |
22 |
Reply Address Element |
SMS Control |
1-255 |
no |
23 |
Enhanced Voice Mail Information |
SMS Control |
0-255 |
no |
24 |
National Language Single Shift |
SMS Control |
1 |
no |
25 |
National Language Locking Shift |
SMS Control |
1 |
no |
26 – 6F |
Reserved for future use |
N/A |
0-255 |
N/A |
70 – 7F |
(U)SIM Toolkit Security Headers |
SMS Control |
0-255 |
? |
80 – 9F |
SME to SME specific use |
SMS Control |
0-255 |
? |
A0 – BF |
Reserved for future use |
N/A |
0-255 |
? |
C0 – DF |
SC specific use |
SMS Control |
0-255 |
? |
E0 – FF |
Reserved for future use |
N/A |
0-255 |
? |
参考资料与拓展阅读
RocketMQ
2022-05-01

主要角色:
- NameServer:服务发现与配置管理
- 服务发现
- 路由
- 配置信息管理
- Broker:
- Broker Master
- Broker Slave
- Producer:生产者
- Consumer:消费者
安装
#!/bin/bash
# 下载RocketMQ二进制包(20MB)
wget https://archive.apache.org/dist/rocketmq/4.9.4/rocketmq-all-4.9.4-bin-release.zip
# 解压RocketMQ安装包
unzip rocketmq-all-4.9.4-bin-release.zip
cd rocketmq-all-4.9.4-bin-release/
# ls
# benchmark/ bin/ conf/ lib/ LICENSE NOTICE README.md
#
# ls bin conf
# bin:
# cachedog.sh* mqbroker* mqnamesrv* play.sh* setcache.sh*
# cleancache.sh* mqbroker.cmd mqnamesrv.cmd README.md startfsrv.sh*
# cleancache.v1.sh* mqbroker.numanode0* mqshutdown* runbroker.cmd tools.cmd
# dledger/ mqbroker.numanode1* mqshutdown.cmd runbroker.sh* tools.sh*
# mqadmin* mqbroker.numanode2* os.sh* runserver.cmd
# mqadmin.cmd mqbroker.numanode3* play.cmd runserver.sh*
#
# conf:
# 2m-2s-async/ 2m-noslave/ dledger/ logback_namesrv.xml plain_acl.yml
# 2m-2s-sync/ broker.conf logback_broker.xml logback_tools.xml tools.yml
启动
# 启动 NameServer
nohup sh bin/mqnamesrv &
# 验证 NameServer 服务是否正常运行
# tail -f ~/logs/rocketmqlogs/namesrv.log
# # The Name Server boot success...
# 启动 Broker
nohup sh bin/mqbroker -n localhost:9876 &
# 验证 Broker 服务是否正常运行
# tail -f ~/logs/rocketmqlogs/broker.log
# # The broker[broker-a,192.169.1.2:10911] boot success...
echo "RocketMQ installed successfully."
停止/重启服务
sh bin/mqshutdown broker
sh bin/mqshutdown namesrv
调整配置
- 限制内存使用
Systemd
vim /etc/systemd/system/rocketmq-namesrv.service
vim /etc/systemd/system/rocketmq-broker.service
# 配置启动命令、环境变量、工作目录、限制资源使用、设置启动顺序、依赖关系等选项
systemctl daemon-reload
然后就可以执行 start, stop, restart, status, reload, enable, disable 等操作了。
控制台(Web UI)
可以通过官方的 rocketmq-dashboard(SpringBoot + React)管理。
最简单的方式就是运行在 Docker 中:
docker run -d --name rocketmq-dashboard -e "JAVA_OPTS=-Drocketmq.namesrv.addr=127.0.0.1:9876" -p 8080:8080 -t apacherocketmq/rocketmq-dashboard:latest
集群
https://cloud.tencent.com/developer/article/1857491
SSH PuTTY
2022-04-29
openssh 8.2 remove ssh-rsa support for security reasons, suggest to use ssh-ed25519 instead.
Windows
2022-04-29
我对开发者十分佩服,几十年如一日的开发这样一个现阶段明显没有盈利可能的系统。等这个项目稳定下来之后,或许很多古老的遗留系统可以收益。
相关的镜像可以在 SourceForge 上取得, 最新的版本是 03/31 发布的 0.4.14 release 19,可以下载 LiveCD 体验。
PS:完整的 ISO 只有 110M,Live 版 80M。
PS:最新版完整镜像的下载链接: https://sourceforge.net/projects/reactos/files/latest/download
项目介绍
1995 年,FreeWin95 项目
1998 年,ReactOS 项目启动

主要用 C 编写。目标是完全不采用 Windows 代码的前提下,对 x86/amd64 平台的 Windows NT 5.2 (Windows Server 2003) 兼容。
代码审核非常严格,曾经由于被怀疑用了反编译 Windows 的代码而自行开展大规模的代码审查。
研发团队规模有限。
GitHub 地址: https://github.com/reactos/reactos


推荐的硬件配置:
- CPU: x86/amd64 兼容处理器
- 内存:256MB (最小 64MB)
- 硬盘:IDE/SATA,主分区至少 350MB
- 显卡:2MB VGA
- CD-ROM,普通键鼠
体验感受
VirtualBox 4C1G 虚拟机,起最新版 Live 镜像,大概 2 分钟后进入桌面(Installing devices 这一步太久了)。
选的 Chinese (RPC)
语言,然后 US
键盘。Run ReactOS Live CD
进来之后,中文都是小方框。
然后重启,选择安装 (Install ReactOS
),提示需要插入安装媒体。
然后还是换成 English (United States)
语言, 可以进入桌面,但是感觉不怎么流畅。
参考资料与拓展阅读
#800
杂事
个人
2022-04-28
请赐予我力量,全力改变那些可以改变的事情,平静接受那些无能为力的事情,拥有智慧区分这两者。
-
2022 年已经过去三分之一,希望今年的年度计划能够落实。年初定的五个主要目标:
-
深挖现有技术栈
- 公司业务熟稔于心
- Golang 达到和 Python 相同的掌握程度
- 英语和数学,达到大学时期要求的水平就行
- 个人项目
目前全部毫无进展。要是再不抓紧,年底又会觉得一年过去啥事都没有做成。
- 技术债越积越多, 不知道何年何月能补齐。难道是退休的时候?
要是我可以不工作也有工资拿, 半年时间, 应该够了吧。
总结已有知识,查漏补缺,然后对想要了解的方向进行一个全面深入的学习。
顶多一年...应该可以了吧...也许。
如果工作中学不到什么,单靠挤一点空闲时间自学确实有压力。
- 希望收入跑赢通胀, 然后房价便宜一点。
不贪心, 打个七折 (➘ 30%) 就够了。
- 二胎计划
- 希望新冠能在今年夏天结束。
- 我想要工作中能有更多机会锻炼自己的表达能力。
我思考过这个表达能力的培养问题,其实质应该是应急情况下的思维能力问题,我习惯于安静的环境思考问题。
在向别人阐述自己观点,或者一般的技术交锋过程中,需要思维能够更加活跃,跟上话题发展的节奏。
PS: 我说的表达能力就是普通的语言能力,不是社交能力。我对社交并不热衷,也没想过那么活蹦乱跳。作为一个技术人员,做好分内工作就行,其他事情爱咋咋地。
Golang
2022-04-28
dlv 是 Golang 生态中一种常见的调试工具,我感觉有点类似 gdb。本文描述其基本用法。
开发者 RPC
2022-04-26
C++
- protocolbuffers/protobuf

Protocol Buffers - Google's data interchange format
- aria2/aria2

aria2 is a lightweight multi-protocol & multi-source, cross platform download utility operated in command-line. It supports HTTP/HTTPS, FTP, SFTP, BitTorrent and Metalink.
- google/flatbuffers

FlatBuffers: Memory Efficient Serialization Library
- apache/incubator-brpc

Industrial-grade RPC framework used throughout Baidu, with 1,000,000+ instances and thousands kinds of services. "brpc" means "better RPC".
- RPCS3/rpcs3

PS3 emulator/debugger
- TarsCloud/Tars

Tars is a high-performance RPC framework based on name service and Tars protocol, also integrated administration platform, and implemented hosting-service via flexible schedule.
- capnproto/capnproto

Cap'n Proto serialization/RPC system - core tools and C++ library
- idealvin/cocoyaxi

A go-style coroutine library in C++11 and more.
- baidu/sofa-pbrpc

A light-weight RPC implement of google protobuf RPC framework.
- zeroc-ice/ice

Comprehensive RPC framework with support for C++, C#, Java, JavaScript, Python and more.
- Tencent/phxrpc

A simple C++ based RPC framework.
- FISCO-BCOS/FISCO-BCOS

FISCO BCOS 是由微众牵头的金链盟主导研发、对外开源、安全可控的企业级金融区块链底层技术平台。 单链配置下,性能 TPS 可达万级。提供群组架构、并行计算、分布式存储、可插拔的共识机制、隐私保护算法、支持全链路国密算法等诸多特性。 经过多个机构、多个应用,长时间在生产环境中的实践检验,具备金融级的高性能、高可用性及高安全性。FISCO BCOS is a secure and reliable financial-grade open-source blockchain platform. The platform provides rich features including group architecture, cross-chain communication protocols, pluggable consensus mechanisms, privacy protection algorithms, OSCCA-approved (Office of State Commercial Cryptography Administration) cryptography algorithms, and distributed storage. Its performance, usability, and security have been testified by many institutional users and successful business applications in a live production environment.
- rpclib/rpclib

rpclib is a modern C++ msgpack-RPC server and client library
- sogou/srpc

High performance, low latency, lightweight enterprise-level RPC system. Supports Baidu bRPC, Tencent tRPC, thrift protocols.
Go
- asim/go-micro

A Go microservices framework
- chai2010/advanced-go-programming-book

:books: 《Go 语言高级编程》开源图书,涵盖 CGO、Go 汇编语言、RPC 实现、Protobuf 插件实现、Web 框架实现、分布式系统等高阶主题(完稿)
- zeromicro/go-zero

A web and RPC framework written in Go. It's born to ensure the stability of the busy sites with resilient design. Builtin goctl greatly improves the development productivity.
- grpc/grpc-go

The Go language implementation of gRPC. HTTP/2 based RPC
- geektutu/7days-golang

7 days golang programs from scratch (web framework Gee, distributed cache GeeCache, object relational mapping ORM framework GeeORM, rpc framework GeeRPC etc) 7 天用 Go 动手写/从零实现系列
- smallnest/rpcx

Best microservices framework in Go, like alibaba Dubbo, but with more features, Scale easily. Try it. Test it. If you feel it's better, use it! 𝐉𝐚𝐯𝐚 有 𝐝𝐮𝐛𝐛𝐨, 𝐆𝐨𝐥𝐚𝐧𝐠 有 𝐫𝐩𝐜𝐱! build for clound!
- roadrunner-server/roadrunner

🤯 High-performance PHP application server, load-balancer and process manager written in Golang
- twitchtv/twirp

A simple RPC framework with protobuf service definitions
- cloudwego/kitex

A high-performance and strong-extensibility Golang RPC framework that helps developers build microservices.
- davyxu/cellnet

High performance, simple, extensible golang open source network library
- hashicorp/go-plugin

Golang plugin system over RPC.
- TarsCloud/TarsGo

A high performance microservice framework in golang. A linux foundation project.
Java
- doocs/advanced-java

😮 Core Interview Questions & Answers For Experienced Java(Backend) Developers | 互联网 Java 工程师进阶知识完全扫盲:涵盖高并发、分布式、高可用、微服务、海量数据处理等领域知识
- apache/dubbo

Apache Dubbo is a high-performance, java based, open source RPC framework.
- redisson/redisson

Redisson - Redis Java client with features of In-Memory Data Grid. Over 50 Redis based Java objects and services: Set, Multimap, SortedSet, Map, List, Queue, Deque, Semaphore, Lock, AtomicLong, Map Reduce, Publish / Subscribe, Bloom filter, Spring Cache, Tomcat, Scheduler, JCache API, Hibernate, MyBatis, RPC, local cache ...
- dianping/cat

CAT 作为服务端项目基础组件,提供了 Java, C/C++, Node.js, Python, Go 等多语言客户端,已经在美团点评的基础架构中间件框架(MVC 框架,RPC 框架,数据库框架,缓存框架等,消息队列,配置系统等)深度集成,为美团点评各业务线提供系统丰富的性能指标、健康状况、实时告警等。
- grpc/grpc-java

The Java gRPC implementation. HTTP/2 based RPC
- nathanmarz/storm

Distributed and fault-tolerant realtime computation: stream processing, continuous computation, distributed RPC, and more
- weibocom/motan

A cross-language remote procedure call(RPC) framework for rapid development of high performance distributed services.
- line/armeria

Your go-to microservice framework for any situation, from the creator of Netty et al. You can build any type of microservice leveraging your favorite technologies, including gRPC, Thrift, Kotlin, Retrofit, Reactive Streams, Spring Boot and Dropwizard.
- sofastack/sofa-rpc

SOFARPC is a high-performance, high-extensibility, production-level Java RPC framework.
Python
- crossbario/autobahn-python

WebSocket and WAMP in Python for Twisted and asyncio
- quantmind/pulsar

Event driven concurrent framework for Python
- lgandx/PCredz

This tool extracts Credit card numbers, NTLM(DCE-RPC, HTTP, SQL, LDAP, etc), Kerberos (AS-REQ Pre-Auth etype 23), HTTP Basic, SNMP, POP, SMTP, FTP, IMAP, etc from a pcap file or from a live interface.
- Thriftpy/thriftpy

Thriftpy has been deprecated, please migrate to https://github.com/Thriftpy/thriftpy2
- tomerfiliba-org/rpyc

RPyC (Remote Python Call) - A transparent and symmetric RPC library for python
- samuelcolvin/arq

Fast job queuing and RPC in python with asyncio and redis.
- arskom/spyne

A transport agnostic sync/async RPC library that focuses on exposing services with a well-defined API using popular protocols.
- jgarzik/python-bitcoinrpc

Python interface to bitcoin's JSON-RPC API
- Pyrlang/Pyrlang

Erlang node implemented in Python 3.5+ (Asyncio-based)
- Thriftpy/thriftpy2

Pure python approach of Apache Thrift.
- kevinhwang91/rnvimr

Make Ranger running in a floating window to communicate with Neovim via RPC
- hakril/PythonForWindows

A codebase aimed to make interaction with Windows and native execution easier
- joshmarshall/jsonrpclib

A Python JSON-RPC over HTTP that mirrors xmlrpclib syntax.
- CiscoDevNet/yang-explorer

An open-source Yang Browser and RPC Builder Application
- phunt/avro-rpc-quickstart

Apache Avro RPC Quick Start.
- pavlov99/json-rpc

🔁 JSON-RPC 1/2 transport implementation. Supports python 2/3 and pypy.
- progrium/duplex

Full duplex modern RPC
- maxcutler/python-wordpress-xmlrpc

Python library for WordPress XML-RPC integration
- studio-ousia/mprpc

A fast Python RPC library
- Ananto30/zero

Zero: A simple, fast, high performance and low latency Python framework (RPC + PubSub) for building microservices or distributed servers
开发者 安全
2022-04-25
OSCHINA 上听说墨菲安全, 是一个 Golang 写的 cli 工具, 收集项目的依赖信息提交到服务器端, 查询可能的安全风险。
根据官方文档,目前支持 Java(maven,gradle),Golang(go mod),Node(npm,yarn),Python(pip)语言。
本文档就是简单的试用一下。
总结:我感觉挺好的,一般来说对于依赖我们都不上心,其实是有很大安全风险在里面。我觉得应该对线上业务的依赖都应该有严格的审查。
如果是安全方面的需求没有那么强烈,用这个工具可以为依赖的管理提供一些帮助。
可以考虑和 CI/CD 继承,如果有安全风险就发出告警信息。
开发者 Python
2022-04-19
一些阶段性目标:
-
参照网上查到的博客和文档,先列出大纲以及制定学习计划
大概以下五个主题的内容:
-
Python 标准库
- Tornado
- Redis
- RabbitMQ (pika)
-
MySQL (SQLAlchemy/pymysql)
-
如果资源方面允许,可以实现一个内部系统开发,进行编码和设计方面的指导
- 阅读项目文档,理解邮件和短信的处理流程,项目结构,以及每个项目的核心逻辑
- 给定一个周边项目进行开发维护,小任务开发(Code Review)
- 从写文档和单元测试开始,逐渐参与核心项目的开发和维护
其他:Linux 基础,Git,我们的开发流程和规范
标准库
- 常用基础库: os, sys, shutil, re, time, datetime, ramdom, json, pickle ...
- 日志: logging
- HTTP 相关: urllib, http
- 邮件相关: email, smtplib, smtpd
- 编码和加密相关: md5, sha, base64, hmac, binascii
- 单元测试: unitest 非常重要
Tornado
- Web 框架先走起来
- 基本用法,比如
add_timeout
, call_later
, add_callback
...
- 了解 IOLoop/IOStream
- 项目开发过程中的一些实践
Redis
- 安装
redis-cli
- 数据类型
- 命令清单
redis
库
RabbitMQ
- 基本概念 (Exchange / Queue / Binding / Channel / Connection)
- 安装和使用
pika
库
- 发布/订阅 (生产, 消费)
MySQL
- 数据类型
- 连接
- 索引
pymysql
/ mysqlclient
库
- SQLAlchemy
育儿 Excel
2022-04-18
一些简单的算术(十以内的加减法)要掰着手指算半天,还总算错,我觉得是训练少了。
目标:能够不假思索地说出答案。
工具:Excel 生成题目,打印到 A4 纸
第一步:数数训练
- 从 1 数到 100
- 从 100 倒数到 1
- 指定两个数字比大小
- 10 以内
- 20 以内
- 100 以内
- 从指定数字往后数指定位
- 从指定数字往前数指定位
第二步:十以内加法训练
- 5 以内的加法,应该没有问题,确认一下。
- 大数
6 ~ 9
+ 小数 0 ~ 5
- 大数
6 ~ 9
+ 大数 6 ~ 9
- 十以内的加法综合训练
第三步:十以内的减法训练
- 5 以内的减法,应该没有问题,确认一下。
- 十以内的减法综合训练
第四步:加法
- 不用进位的加法
- 进位加法
11 ~ 19
+ 0 ~ 9
- 更大数的进位加法(加强)
- 100 以内加法综合训练
第四步:减法
- 不用借位减法
- 借位减法
11 ~ 19
- 0 ~ 9
- 更大数的借位减法(加强)
- 100 以内减法综合训练