善意提醒

如果您打开本站很慢,布局排版混乱,并且看不到图片,那么可能是因为您还没有掌握用科学的方法上网的本领。

2024-11-29

不喜欢中国的北方

因为工作的关系,在中国的北方呆过不短的时间。2002年至2003年,我在乌鲁木齐待过大约半年。2007年至2010年间,也多次去北京出差,有几次的时长也能按月计算。
生活上,大部分时间还是爱呆在南方,或者说,东南沿海地区。不知道这是因还是果,不太好说。但主观上我的确可以这样说:我不习惯,或者说,不喜欢中国的北方。

图片来自网络

刚出乌鲁木齐机场,我的第一反应是低头看了一眼我的腿,确认一下我的确有穿裤子。我差点以为我是光着腿出来的。
是的,室内有暖气,18度以上,甚至可以只穿单衣。只是宅在家里倒是无所谓。
但是,如果你要外出,出门前得把自己包裹得严严实实的。帽子、手套、靴子、围巾……。如果帽子不够大,或许还需要口罩和耳罩。进到室内,又得脱,并没有那么舒服。
而且,如果在户外待的时间长,超过一个小时,就又开始难受了。
即使在夏天,太阳底下挺热,一走到阴影里面,温度就掉下来了。我也不知道这算好事还是坏事,反正不习惯。近些年据说这种情况有变化?那还真是托了圣婴的福了。

有的人说南方的湿冷更难受,可能有很多上海人也会同意这个说法。不过我还是觉得北方的干冷更难以接受。
别的不说,光是啪啪作响的静电,就够让我难受的了。一天里面不知道要被电多少次。
还有干裂的嘴唇。我到乌鲁木齐之后,嘴唇裂了快一个月。那段时间完全不敢笑,一笑就淌血。吃饭的表情也很奇怪。
皮肤也很干燥,不勤快涂东西的话,也是简直要裂开的程度。没办法,水分都冻成冰雪躺在地上呢。

据说是因为烧煤供暖的缘故,空气质量普遍不佳。
住在城市里可能一时还不觉得,有一次去到山上陪客户滑雪,远远望去,整个城市就像被扣在一口黑锅里似的。
路边的雪刚落下的时候还挺白,第二天早上就变灰色。如果接下来温度有所回升,就变成脏水四处横流,或者化身为灰黑色的烂泥,你还拿它真没办法。
还有就是沙尘暴。近些年或许好一些了?但我对于在北京开完会后推开门看到之前还干干净净的走廊扶手上堆着至少五毫米厚的黄土,不是灰,真的是土,那种震撼让我永生难忘。

服务

一开始是一同出差的同事跟我讲的,不过随后我也深有同感。而且估计这应该也算是国内共识:要论服务态度和意识,肯定是由南往北越来越差。同样是在餐馆里用餐,在深圳就感觉很好,在上海也还行,到了北京,服务员的鼻孔都是朝天的,爱理不理。
平心而论,北方的消费肯定要便宜一些。北京暂且抛开不谈。南方和北方的菜,在份量上就会有明显差别。但是这也无法抵消主观感受上的差异。
在南方可以住到干净舒适的酒店,到了北方就是脏乱差不讲究。即使表面上富丽堂皇,茶杯摆得整整齐齐,但是就是不会让你觉得很舒服。


说起来吧,这些问题有一些跟「中国」也是没关系的,全球都如此。但有一些想一想也就没那么容易说服自己了。
不管吧,情况就是这么个情况,现实如此,我只有自己去做选择题了。

2024-11-14

编程随想:还会有下一次的

图片来自网络,与本文无关

昨天,有同事收到测试部门反馈的一个Bug。

他的第一反应,是下了一个判断:「这个Bug可能是因为XXX导致的。」
随后他就动手去改了。

作为同一个办公室的同事,我听到了他说的话,出了一身冷汗。
当然,也许是因为我经验比他多一些。不过,或许更因为我比他更为谨慎一些。
我问他:「你能确定这个Bug的原因吗?有没有重现过?」
他说不能确定,没有去重现过。
我又问他:「你确定你改了以后这个Bug就没有了吗?」
他说也许吧,先改了试试看。

那我觉得这个Bug就还会有下一次的。

正确的做事方法,我当然告诉了他,看他听不听了。
然后,我也去跟测试部门打了个招呼,让他们留神一点。
放任不管的话,养老金说不定就没了。

对了,我真的只是在说编程而已。
另外,无论我还是这位同事,婚姻状况都还没出问题。

2024-10-15

面对真实的自己

最近除了在整理工作上的文档和笔记,也有整理自己的陈年Blog。

之前其实已经筛选过一遍,放了一些到Blogger上。当时的筛选标准,一是要有些营养,对别人要有点用处。那种纯粹个人流水账式的Blog,就没好意思放上来,但是我其实写了挺多。二则是一些自己觉得肤浅、害臊乃至羞愧的内容,出于个人情感的缘故,也没有往上放。

不过这次,我又陆陆续续放了一些上来。不符合以上两类筛选标准的旧Blog,我基本上一篇篇又补了回来。原因无它,只为了一句话:「面对真实的自己」。

图片来自网络,与本人无关

是的,我以前就是这个德性。不管说过什么样让自己后悔的话,不管干过什么让自己觉得「我不认识这个人」的事情,那就是当时的我,一个真实的我。我当时就是那样想的,那样做的。去掩饰,或者去粉饰,都是没有意义的。如果我连过去的自己,都不敢面对,如何面对未来的自己?

所以,尽管看了会面红耳赤(不是某些人想像的那种),想找个地洞钻下去,我还是会把这些内容慢慢地放上来。整理的过程中,我有点惊讶于自己以前那么「能写」,也拾回了不少已然忘却的东西。这些东西让我更加坚信,自己的记忆并不是被植入的,过去那许多年,还算是没有白活。我是有历史的,有流水的,而不是现在这一个Snapshot而已。

有一些内容,我会在自己不再害怕任何东西了以后,选择把它们公开。一直写到死,这就是我的意思。

2024-10-12

调整了一下Blogger

很怀念自己之前的旧Drupal站点,一直很遗憾Blogger没法像它那样「打扮」。

今天突然想起来,我又不是不会HTML/CSS/Javscript,而且我也有F12,Blogger也让我自定义站点的页面,那我有什么做不到的?说干就干起来。

是你吗?

于是就有了现在这个Header部分。是的,我的大头像又回来了。

字体跟旧版还是有所不同,我当然也能做到改得一模一样,不过现在这个样子我觉得也OK。先不去动了。

顺点也解决了一些问题,比如发现页面里面有一个失效的js。回想了一下,发现是Facebook的Like按钮。没用的花哨玩意儿,何况我Facebook账号早就被杀了。

右侧的布局也调整了一下。联系方式和Profile什么的就去掉了,也是没用的玩意儿。
Blog展示的细节也调整过了。发现有一篇Blog下面居然有「more」,回想起来是编辑器里面那个看似<hr>实则不是的功能在捣鬼。

最后,在顶部放了一个提示。通过自定义域名,我的站点在阿兹卡班也还是勉强能访问的。这件事情,跟我那十几年不变的标语一样,大家懂就懂,不懂也就算了。

2024-10-11

死去的Blog正在攻击着我的记忆

图片来自Stable Diffusion,纯属虚构

因为工作调整的原因,整理一些笔记的时候,无意中翻到了过去的Blog,用Drupal5在自己个人电脑上架设的Blog。

已经过去很多年了。技术都已经落伍,过时了很久,以至于我无法通过源代码编译以外的任何方法再把它架设起来。但是虚拟机还在,站点就还在。Red Hat Linux 7.3跑起来,显示输入http开头的URL,过去的记忆又再次出现在我的面前。

我应该不算是一个「感性」的人吧?看到这些的时候,心中的反应跟「无动于衷」相去也不远。不过,看到右下角那一些「友情链接」,我还是有点心酸。

曾经的友情链接

它们一个都打不开了。


不能排除,其中有一些可能「转世」去了别的地方,甚至不能排除某些人还在关注着我这个Blog。但是,Blog是真真正正都死了。

Blogcn和BlogBus是真没有了,MySpace也算是。新浪博客倒是还在,不过仅限作者本人登录后才能查看。说起来的确是比较「安全」的做法。这年头,捂你嘴可能真的是为你好吧?想不通的人,还埋在夹边沟呢。

比较让我惊讶的是,dzxr连自己的.com域名也不要了。


以现在人的生活方式,还会有人持之以恒且不求功利地写东西吗?肯定还有,但是不多了。
再说,我也的确「遁世」过很久,没法苛责别人。能用来纪念的,也只能是自己继续坚持写下去吧。

直到我去死为止。

2024-10-10

总公司同事前来交流高新申报的笔记

图片来自网络,与本人及所供职公司无关

总公司那边有同事过来交流,关于申报高新技术企业(以下简称「高新」)以及成功后的续期的相关经验。我作为技术负责人旁听,留下了一些笔记。

已经是过去了一段时间的事情了。现在正在整理相关笔记,想想索性记录到Blog里面好了。或许其他人也用得上。不见得是什么权威内容,好歹有一些思路。

听到的要点整理如下:

  • 最重要的就是软件著作权(以下简称「软著」)。每年都要5个。时间上需要平均一些,避免出现年底集中申请的情况。
  • 申报成功后证书有效期上写的是三年。不过随后的软著申请不能停,不然续期会遇到问题。续期的时候这三年的情况都要看。
  • 高新技术企业和「高新技术成果转化」还不一样。
  • 审核部门以前是科技部,现在改成工信部了。
  • 加计扣除」是高新申报成功的好处之一。
  • 收到的高新技术企业信息调查表,一定要填写。
  • 软件13%的税,技术服务6%的税。
  • 软件企业也有税收减免。

不过,这些现在都已经不重要了。

2024-09-29

信创踩坑笔记

图片来自网络

1. 银河麒麟(Kylin V10)

银河麒麟算是好的,毕竟高仿CentOS。看它的文档,似乎V4的时候还是Ubuntu/Debian系的,现在的V10已经转到RedHat/CentOS派系下了。

我们的程序基本都是静态链接,所以就还好。唯一动态链接的是OpenSSL,这个在《编译自己的CentOS7 OpenSSL 1.0.2u动态链接库》这篇Blog中已经介绍过了。

1.1. ldconfig

说起来算个坑的,就是它的SP2版本的ldconfig无法正确读取被patchelf改过SONAME的库,说什么「已被截断」。搜了一下,说是属于ldconfig的Bug。patchelf改过soname的so库,里面的段顺序会变。但规范里面并没写顺序是有保障的,ldconfig不应该自行假设顺序一定是那个样子。

有人说这是上游供应链(glibc)的Bug。的确无论SP3的哪个版本都是好的。但我看SP2和SP3的glibc的版本也没看出来有什么变化,这里先存疑一下吧。
我的应对方案就是SP2下就不改SONAME了,难看就难看一些。

1.2. VMware

接下来这一个实际上应该放在最前面,不过只是因为我用了VMware来安装这些而已。不见得所有人都会遇到。

银河麒麟V10安装在VMware上的时候,显示分辨率默认是800×600。在这种情况下,无法调整显示分辨率,因为「保存」按钮被挡在屏幕外面了。
解决方法是用xrandr,例如:

xrandr -s 1440x900_60

最后一个参数是刷新率(60Hz)。有些Blog上说这里只能用xrandr列出来的选项,但其实未必,只要显示器支持就行。
另外,有些Blog上说这种方式只能临时调整,重启后效果就没了。的确如此,可是现在屏幕大了,你就可以用UI来正式调整显示分辨率了,不是吗?

1.3. 9090端口

我们有个服务,默认启动在9090端口上。结果等产品要上线到生产环境的时候,运维人员去启动的时候得到了报错,一看才发现端口被人占了
问题是我自己之前搭环境测试的时候,没有遇到这种情况。估计因为我的银河麒麟V10是「最小化安装」,而客户那边生产环境则没有这样做吧。

2. 达梦(DM8)

总的来说,在Windows上安装达梦8的过程要顺畅很多,没遇到什么问题。Linux下就开始有坑。

2.1 ulimit

准备阶段的第一个坑是ulimit的问题,之前已经先写了Blog,这里就只给出链接了《Linux下修改ulimit不能完全生效的问题》。这个坑严格来说不算麒麟也不算达梦的问题,而且不见得所有人都会遇上。

2.2. cdrom

第二个坑是挂载光驱。挂上来之后没有x权限,但不知道怎么回事,用-o exec也挂不出来x权限。最后只好用命令行强制运行解决:

bash DMInstall.bin

接下来的安装倒是没出多大问题。我在Linux上安装达梦的目的只是为了抠出里面的bin、include和drivers目录来,用来制作Python和PHP的运行环境而已。所以后续运维的踩坑经验我就无法提供提供了。

2.3. Python

我们的Python运行环境是用Conda搭的,有2.7和3.5两个版本。按照达梦官方文档的说法(那文档写得不好,链接恕我不放了,自己搜吧),需要安装达梦客户端,然后再编译驱动。照着操作就可以,没什么大坑。

2.3.1. ldconfig

我是从一台安装了达梦客户端的Linux机器上把bin、include、drivers这三个目录抠了出来,设了一下LD_LIBRARY_PATH,然后去Conda环境里面编译驱动。这样做是没问题。

但是当我把目录放/etc/ld.conf.d里面之后,一跑ldconfig,sshd直接挂掉了。数个SSH会话同时被踢,吓了我一大跳,还以为被黑客入侵了。

好在tty登录没有问题,看起来是OpenSSL导致了OpenSSH不能用了。一看达梦的bin目录,libcrypto.so和libssl.so就这样裸躺在里面,服了。最后还是只能用回LD_LIBRARY_PATH方案。

2.3.2. 多线程

接下来我们尝试在Python环境中登录达梦数据库。有一个小坑:达梦的dmPython.connect会开子线程来进行登录。我们的Python环境在Python解释器跑起来后把nproc改成了0,结果就CoreDump了。看过CoreDump里面的CallStack才明白原因。看起来C代码里面的异常捕获,dmPython完全没有做嘛。抛个Python异常也好啊。

2.4. PHP

达梦的文档在这一部分有比较大的问题。
首先,有点语无伦次。无论是yum还是源代码编译,都是指的PHP的安装方式,但达梦的部分应该都是一样的。然而文档中却说得好像不一样。
其次,版本混乱。安装代码中同时有7和5的库,显然是更新文档的时候没有更新完整。
最后,其交代的技术细节存在着问题,至少与事实不符。我按照其中列出的DPI库准备的环境,PHP的PDO_DM库完全加载不起来。

我想办法得到了一份正确的so依赖列表,比达梦文档中给出的要多,多了不少。主要是因为libdmcalc.so和libdmdta.so导致的。我觉得我直接给出我的so库列表并不是一个好主意,毕竟DM8的版本肯定也在不时地变化。更有用的是介绍我的方法。

我的方法也很简单:找个编辑器打开达梦的两个PDO的so库,然后就搜「.so」。ldd中看得见的,这样能搜到。看不见的,那种用dl_open打开的,这样也能搜到。然后顺藤摸瓜就行。貌似DPI的那些so库都还不会用dl_open。
当然,将来达梦如果对so的内容进行混淆或加密,那我就不敢说这样能行了。希望它不会犯这个蠢。

后面就还好了。我一度担心OpenSSL又惹事,但大概是我们的PHP环境比较简单,没惹出什么麻烦。我直接把它们塞进了一个docker镜像里面,这部分的工作成果总算是被固化了下来。

2024-09-14

Linux下修改ulimit不能完全生效的问题

前言:本文只打算作为「技术笔记」来写,对关键的要点进行一下点拨就完事,没想写成教程。或许能让熟手解决麻烦,如果是新手的话,最好是先有相关的基础知识和经验。当然,直接喂给AI,让它嚼过再给你慢慢解释,可能也是一个办法。

这些天还是在折腾信创的事情。安装了银河麒麟V10 SP2的一个默认设置的版本,带了可视化界面,准备用于安装「达梦」。
达梦的安装手册写得有一些问题,缺了一些要点,不过对于有一定经验的人而言,还算能解决。手册中有一个要求,就是要把ulimit里面的open files数量调大。原始的1024,看起来不太够用。

图片来自网络

对Linux特别是CentOS7熟悉的人,应该反应过来了。不要直接改ulimit,应该去改/etc/security/limits.conf:

* soft nofile 65535
* hard nofile 65535

改完之后,重新登录的账号就已经是新的open files上限了。简单重启一下就应该万事OK了。

可是,不,没有那么简单!(莫名其妙的英式中文)


在我看来,改完重启以后,对于非root用户似乎完全没有效果。
root账号好像真的是OK了。但达梦的安装手册提到需要创建专用的dmdba账号用于DBMS的安装。我在可视化界面登录dmdba账号后,打开「终端」窗口,ulimit还是1024。

测试下来,发现:

  • ssh上来的session有效果;
  • su切换过去的账号有效果。

这说明对/etc/security/limits.conf的修改还是有效果的,只是不知道为什么在某些场合下不能生效。
百思不得其解。最后找到这篇Blog,是博客园的。标题起得有点不好找:《systemd service 设置limit,不生效问题》。它引用的原文的URL已经失效了,所以我还是得把要点直接再说一下。简单来说就是:

  1. 要修改用systemctl启动的服务的ulimit,需要修改/etc/systemd/system.conf
  2. 要修改从可视化界面登录的用户的ulimit,需要修改/etc/systemd/user.conf

实际上的情况比这个要复杂一些。第二点不是原文中的描述,是我自己试出来的。我目前也无意去成为一个Linux或银河麒麟方面的专家,所以就暂时不作更多的探索了。

另外,修改了/etc/systemd/system.conf以后,需要先重启systemd:

systemctl daemon-reexec

然后用systemctl启动/重新启动的服务,才能用上新的ulimit设置。
毕竟咱们改的是systemd的配置文件,对吧。

2024-09-13

SSD散热铜片导致的故障

我的HTPC,一开始真的只是打算用来当作HTPC用,所以SSD只有256GB。后来儿子要玩游戏,因此很快就不够用了。于是大约两年前,我换了一条aigo的NVMe M.2 SSD,P2000,1TB的容量。不是什么好东西,不过因为我在公司里面用过同品牌同型号的产品,心中有点数(相比之下,aigo P3000 Pro简直就是巨坑),所以也就跟着买了。

用到现在倒也都没有出什么问题,但散热真的是个问题。之前的256GB SSD因为有马甲,还不觉得散热有问题。但这块P2000是个「裸条」,我一开始复制大文件,比如电影,温度就往上窜。温度高到了一定程度以后,速度就掉下来了,后来还开始掉盘。于是我又去买了一个散热铜片,粘上以后好了很多,不再有散热问题了。

图片来自网络,非同款,非广告

这个散热铜片有单面款和双面款。我的HTPC是一个很小的ITX机箱,而且主板的M.2插槽在背面。如果贴双面,会不会接触到主板背面的针脚或元件?我的确有这个担心。看别人的评测,说还有一定高度,不会碰到。我自己试下来,也的确如此,于是就这样用了下去。快两年以来,都没有什么问题。

以上是前言。


最近,我一直在与这台HTPC的「关机」方面的顽疾作斗争。
一开始是开机以后自动关机,偶尔有之。最近则变成关机关不掉,关机变重启。重启有的时候来得很快,有的时候时间都说不清。比如昨天,我关了机器去上班,下午三点多,家里都没有人的时候,它自己开机了。要真是能远程唤醒也就罢了,可当我正经来设置的时候,又没法用。
于是昨晚我把BIOS设置给LOAD DEFAULT了。以前一直没能狠下这个心,终于世界清净了。

然而,今天早上,我再想开机的时候,发现机器开不起来了。

我绞尽脑汁地回想我到底做了什么导致的这个后果?
不是BIOS设置的问题,因为现在甚至不给我进BIOS的机会。CPU风扇转一小会儿就断电停了。
拔掉内存,可以长期通电,可见不是电源问题。
CPU烧了?过热保护?但从加电到断电的时间非常短,CPU再热也不至于这么一小会儿都撑不住。何况风扇并没有停。不过保险起见,我还是把前不久换的散热器拆了,重新打了硅胶。还是没有效果。

把配件全拆了,就剩主板和电源,裸接,还是点不亮。那么,主板、CPU,还有就是背面的SSD了。
我很不报希望地把SSD卸了,再加电。这次亮了,进BIOS了。


带着难以置信的心情,我反复试了几次,能够确认就是SSD导致的问题。
难道是SSD坏了?就算不认盘,也不至于连BIOS也进不去吧?不过NVMe走的路线不同,或许会导致CPU故障类似的样子。
我把SSD拆下来,放在NVMe M.2移动硬盘盒上,用笔记本读。识别起来毫无困难,里面内容也没问题,看起来SSD没坏。我算是松了一口气。

好吧,唯一可以怀疑的,就是这个散热片了。我再次看了看主板背面的空间,感觉有可能接触到。身边没有趁手又够薄的绝缘片,于是我还是费了半天劲把散热片拆了下来。还好P2000没有缓存芯片,背面没有元件。而且上次换散热器的时候,送了一片用来刮硅胶的薄塑料片……

拆了这块粘在SSD背面的铜散热片以后,果然故障就消失了。虽然总算是解决了,但还得装回去,最后这一趟折腾总共花了我两个半小时,还一手的伤口。迷你,不是没有代价的。


复盘一下,多半是因为热胀冷缩的关系,铜散热片不知道怎么就跟主板背面的针脚或元件接触上了,于是主板直接短路保护了。我估计针脚的可能性大一些。之前我HTPC一直没关,基本上都是热机的状态,所以工况跟昨晚不太一样。

这块散热铜片,我是不打算装回去了。SSD上的芯片都在正面,正面的散热铜片还在,背面只有PCB板而已。而且背面的散热铜片以前跟主板的间隙就很近,即使没短路,我觉得也不会有什么散热效果。
只是,早知道如此,当初还不如直接买单面的铜片,还便宜一些。

2024-09-10

把Google Code Prettify应用至Blogger

图片来自网络

记得以前给自己的Blogger部署过Google Code Prettify,不过后来可能是因为主题被重置过,效果没了。今天把它重新找了回来,日后也会逐渐套用至需要的Blog上。本文就作为相关内容的技术笔记吧。

部署

在Blogger后台中,点「主题背景」,然后进行「自定义」,去「修改HTML」。
在head标签中放置:

<script src='https://cdn.rawgit.com/google/code-prettify/master/loader/run_prettify.js'/>

然后用下列标签把代码括起来,就可以实现本文中的代码块效果:

<pre class="prettyprint">……</pre>

pre标签中的代码按原始格式存放即可,不过小于号(<)和大于号(>)仍然要进行转义。


以下是一些常用到的option,更多的内容烦请移驾官方Github页面

主题

在引用run_prettify.js的时候,URL后面加一个参数skin即可。例如:

<script src='https://cdn.rawgit.com/google/code-prettify/master/loader/run_prettify.js?skin=desert'/>

目前有五种主题,预览图点这里

不标记为代码

用一组带nocode样式的span标签括起来即可,还可以加上自己的样式。例如

<span class="nocode" style="color: red;">注意</span>

语言指定

在pre标签中指定lang-*样式,例如:

<pre class="prettyprint lang-sh">
if [ ! -d '/myfile' ]
then
    mkdir /myfile
fi
</pre>
<pre class="prettyprint lang-cpp">
class A
{
public:
    int a;
}
</pre>

内置支持的语言有["bsh", "c", "cc", "cpp", "cs", "csh", "cyc", "cv", "htm", "html", "java", "js", "m", "mxml", "perl", "pl", "pm", "py", "rb", "sh", "xhtml", "xml", "xsl"],还有一些可以通过extensions进行支持,参见官网页面。

自动换行

有些代码有可能把屏幕宽度撑得很大。要想自动换行的话,在head标签中添加:

<style>
pre {
  white-space: pre-wrap;
  word-wrap: break-word;
  word-break: break-all;
}
</style>

这里的效果是按字母换行,可能会切断单词。如果要按单词换行,去掉word-break这一行。详细的解释参见我的另一篇Blog《关于表格内文字换行的再研究》。