阅读视图

发现新文章,点击刷新页面。

Golang默认Http Client导致的cannot assign requested address错误

问题表现

重现代码:

package main

import (
	"fmt"
	"io"
	"net/http"
	"time"
)

func main() {

	client := &http.Client{
		Timeout: time.Duration(3) * time.Second,
	}

	for i := 0; i < 100; i++ {
		go func() {
			for {
				req, _ := http.NewRequest(http.MethodGet, "https://baidu.com", nil)

				rsp, err := client.Do(req)
				if err != nil {
					fmt.Println("request failed", err)
					continue
				}

				rsp.Body.Close()

				body, err := io.ReadAll(rsp.Body)
				if err != nil {
					fmt.Println("read body failed", err)
					continue
				}

				fmt.Println(string(body))
			}
		}()
	}

	select {}
}

启动后,随着请求越来越多,很快就出现了"cannot assign requested address"错误,服务器出现大量TIME_WAIT连接。

清明踏春,爬山看海

自从买了登山杖,娃一直说想去爬山。

前段时间天气一直不好,山上也还是光秃秃的,就一直没去。

趁着清明假期,带娃爬山去。

去年假期去过一次香山,路上超堵,这次还是选择了离家不远的百望山:好爬不累。

购入小牛G400T电动车

去年10月底,考虑到老的绿源电动车已经骑了5年,电池越来越不行,马上要冬天了,考虑换个新电动车。

到各个品牌店里转了一圈,发现都没有车子,说是新规的缘故,要到11月份才能有新车。

北京的三月飞雪

盼了一冬天的雪没下,开春了,来了场大雪。

wrenAI本地LLM模型部署

Open-source GenBI AI Agent that empowers data-driven teams to chat with their data to generate Text-to-SQL, charts, spreadsheets, reports, and BI.

WrenAI 是一个开源的Text-SQL 的工具,通过导入数据库结构,通过提问的方式生成SQL。

天津一日游

娃看完中华寻宝记,一直想去天津转转。

大年初九,返京第二天,带娃错峰去一趟天津。

7点出门,直奔北京南站,一路不敢耽搁,在发车前10分钟赶上了车。

2024年终总结

2024年已经过去3个月了,这篇年终总结从元旦拖到了现在。

2024年是我的本命年,这一年发生了很多事,这一年过的并不太如意。

早就想要总结这一年,但不知道从哪下笔。

停止使用staticfile.org服务

昨天像往常一样打开博客,发现评论没有加载出来。

一开始以为是手机网络问题,用电脑复现了一下,发现twikoo的js访问报错了。

使用 ImageMagick 自动添加水印,保护图片版权

背景

细心的朋友可能会发现,我的博客图片都带上了水印。

经过博客被恶意镜像这个事情后,我一直在思考如何防止内容被恶意盗用,尤其是博客里的一些图片。

当Hugo遇上AVIF,优化图片加载这篇文章里,使用了ImageMagick工具做了图片压缩。

当时文章最后说留了个坑,其实就是今天的这篇内容,利用ImageMagick自动给图片添加水印。

如何注册一个.sol域名

Livid大佬新搞了个支持Solana的IPFS/IPNS网关,了解到还有一个.sol的web3域名。

Solana域名服务(SNS)的目标是提供一种去中心化且可负担的方式,将域名(.sol)和链上数据连接起来。这些链上数据可以是SOL地址、 IPFS CID、图片、文本、或者任何其它的东西。

奥森公园半日游

假期第三天,腰间盘犯了,在家躺了三天。

假期最后一天,感觉轻了许多,今天北京天气非常好,带娃出来走走。

昌平42公里骑行绿道打卡

五一的时候带娃骑过南边这段,网上查了说北边这段不好骑,难得2号下午有空,决定先自己走一遍看看。

从家附近的奥北森林公园开始,骑行到沙河水库,整个行程近30公里,耗时3个小时左右。

十月一日爬慕田峪长城

早上5点半起床洗漱,6点出门打车直奔清河站,6点50的火车S515清河-雁栖湖。

虽然坐地铁经常路过清河站,但还是第一次来清河站坐车。

我们提前20分钟到的车站,已经开始排队了。

博客被恶意镜像

起因

9月初的时候,在Google Search Console里发现了一个外链,域名是**.top

随手点过去看了下,发现居然跟我的博客内容一模一样,就是内容变成了繁体。

Github Pages 部署流程解析

上周末在搭建个人锻炼页面时,遇到个Github Pages部署的困惑。

看了running_page项目文档,是支持部署到Github Pages页面的,对应的操作流程定义在github/workflows/gh-pages.yml文件。

    - name: Install dependencies
    run: pnpm install
    - name: Build
    run: PATH_PREFIX=/${{ github.event.repository.name }} pnpm build

    - name: Upload artifact
    uses: actions/upload-pages-artifact@v3
    with:
        # Upload dist repository
        path: './dist'
    - name: Deploy to GitHub Pages
    id: deployment
    uses: actions/deploy-pages@v4

核心逻辑就是上面这段。

搭建个人锻炼页面

工作的缘故,平时基本一坐一天,缺少运动。

时间久了,各种毛病也就出来了。

搬到新大楼后,每天中午吃完饭楼下遛个弯,走一走,身体精神也好了很多。

坚持了一段时间,也不了了之了。

你好 Follow

Follow: Next generation information browser.

最近博客圈开始流行Follow邀请码,大家各种求码,一码难求。

蹲在Discord群里一周,虽然时有发码,但最终还是狼多肉少,抢不到码呀。

中秋爬山

中秋第一天,娃约了同学在公园玩,骑车、滑轮滑,晚上娃带我去了她说非常好吃的一家店吃饭。

晚上回来,想着第二天在家呆一天也是看电视,打算带她爬长城,查了一下,往返的票早已售罄,只好放弃这个方案。

Google Adsense的审核之旅

中午的时候,突然收到一条消息,打开一看,提示我的Google Adsense审核通过了。

偶然发现Google Adsense里居然有40美金,想起来是之前老博客加的广告。

一次简短的青岛之行

刚放暑假的时候,就答应了娃带她去一趟青岛。

8月份要回老家,所以定在了7月中下旬出发。

车票/酒店都订好了,结果来了个台风格美。

出发前一周一直在查天气,就怕去了一直下雨。

解决 "undeclared name: any (requires version go1.18 or later)" 编译错误

$ go install google.golang.org/protobuf/cmd/protoc-gen-go@latest
$ 
$ protoc-gen-go --version
protoc-gen-go v1.34.2
$ 
$ sh make.sh
user.pb.go:123:45: undeclared name: any (requires version go1.18 or later)
$ 

流水线编译报错,其中make.sh文件代码:

...

protoc -I=./ --proto_path=./ --go_out=./ --go_opt=paths=source_relative user.proto 

...

go build

同样的代码在本机编译就没问题,但是放到流水线里编译就报上面的错误。

302跳转的跨域问题(CORS)

302跳转的跨域问题

场景一:302不返回跨域头

请求

GET /302 HTTP/1.1
Host: liudon.xyz
Origin: https://www.baidu.com
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36

返回

HTTP/1.1 200 OK
Cache-Control: private, max-age=0, no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Cf-Ray: 88535773eaf5107e-HKG
Content-Length: 143
Content-Type: text/html
Date: Fri, 17 May 2024 11:42:00 GMT
Expires: Thu, 01 Jan 1970 00:00:01 GMT
Location: https://liudon.org
Server: cloudflare
Vary: Accept-Encoding

浏览器报错

GORM增加sqlcommenter特性

什么是sqlcommenter?

sqlcommenter is a suite of middlewares/plugins that enable your ORMs to augment SQL statements before execution, with comments containing information about the code that caused its execution. This helps in easily correlating slow performance with source code and giving insights into backend database performance. In short it provides some observability into the state of your client-side applications and their impact on the database’s server-side.

源码分析:GORM是如何生成sql的

gorm下实现sqlcommenter过程中,遇到一些问题,顺便把gorm整个流程梳理了一遍,整理记录一下。

gorm使用示例

package main

import (
  "gorm.io/driver/mysql"
  "gorm.io/gorm"
)

type Product struct {
  gorm.Model
  Code  string
  Price uint
}

func main() {
  // 参考 https://github.com/go-sql-driver/mysql#dsn-data-source-name 获取详情
  dsn := "user:pass@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"
  db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
  
  var product Product
  db.First(&product, 1) // 根据整型主键查找
}

我们以First查询为例,看一下是怎么转成具体sql的。

工银亚洲网银密码重置

18年的时候办了张工银亚洲的银行卡,好几年没有用过了。

今年想起来了,发现网银登不上了,密码忘了。

最悲剧的是,试了超过10次,账户冻结了。

打95588咨询了一下,说是可以内地见证方式修改密码,只需要带上港澳通行证和身份证即可。

加速Cloudflare访问

背景

博客架构

这是当前的博客架构,文件保存在Github仓库,通过Cloudflare Page提供访问。

国内访问情况

众所周知,在国内,Cloudflare的CDN属于反向加速,平均耗时在1.5s左右。

2023年终总结

2023年过完了,是时候来个总结了。

博客

2023年一共更新了15篇内容,共计12000字。

Google Analytics全年统计

访问Top3的文章:

2023年12月北京暴雪记录

记录暴雪下普通打工人的生活。

12月14日 周四

北京的雪已经连着下了两天了。

12月11日,也是因为下雪,晚上打车打到10点半才叫到车。

所以这次下雪后,晚上就早走了。

使用Hugo实现响应式和优化的图片

继续我们的博客优化之旅,本篇内容我们将介绍如何使用Hugo实现响应式和优化的图片。

问题

在之前文章里,通过腾讯云数据万象实现了图片优化能力,具体的可参考文章累计布局偏移修复方案改进 —— 自动生成图片宽高

经过一段运行后,发现这里有一个弊端。

Run hugo --gc --minify --cleanDestinationDir
Start building sites … 
hugo v0.119.0-b84644c008e0dc2c4b67bd69cccf87a41a03937e linux/amd64 BuildDate=2023-09-24T15:20:17Z VendorInfo=gohugoio

ERROR Failed to get JSON resource "https://static.***.com/64412246-9050f100-d0c1-11e9-893a-f9b0766533ad.png?imageInfo&t=1698674110": Get "https://static.***.com/64412246-9050f100-d0c1-11e9-893a-f9b0766533ad.png?imageInfo&t=1698674110": stream error: stream ID 1; STREAM_CLOSED; received from peer
ERROR Failed to get JSON resource "https://static.***.com/SkRx5uFwQ8Cliyq.jpg?imageInfo&t=1698674110": Get "https://static.***.com/SkRx5uFwQ8Cliyq.jpg?imageInfo&t=1698674110": stream error: stream ID 3; STREAM_CLOSED; received from peer

随着图片数量增多,因为需要调接口查询图片信息,这里构建耗时变长,同时也特别容易出现超时导致构建失败。

加速Google Analytics

起因

Google Analytics是一款优秀的流量分析服务,集成方便,使用简单。

最近在优化页面访问速度,发现Google Analytics是一个优化点。

优化

1. 访问加速

国内访问Google Analytics很慢,同时还面临着各种广告屏蔽插件拦截。

使用Google Indexing API加速博客收录

对于一个新站点来说,总是想着能让搜索引擎快点收录网站内容。

今天,我们就来介绍一种利用Google Indexing API接口,通过Github Actions实现部署时通知Google抓取页面内容。

在Netlify上部署Twikoo评论系统

在本篇文章里,我会介绍如何在Netlify上部署Twikoo评论系统,如何接入到静态博客Hugo,以及如何实现Twikoo系统版本自动更新。

2024年7月30日更新:因为Github接口策略调整,原有的匿名通过接口获取版本号方法失效,已更改为带token方式请求接口获取版本号,详见workflow里Get twikoo version步骤配置。

利用Github Actions定时抓取微博

背景

在微博上关注了一些用户,比如tk教主月风

但是有些内容过段时间不可见了,所以希望可以定时抓取微博归档备份下来。

实现方案

整体思路:利用Github ActionsScheduled任务,定时执行抓取shell脚本,将内容保存到文件,提交到Github仓库。

北大口腔牙周刮治记录

病情

上次洗完牙后,还是不时有出血的情况。

前段时间更是出现牙龈劈开一块肉,特别容易塞东西的情况。

于是,又跑到医院来看牙了。

医生检查后,说是牙周病,需要牙周刮治,要约到8月份了。

故乡回忆之旅

赶在8月底,趁着娃暑假的尾声,回了趟老家。

老家有条俗语,“永福庄的街,三里长”。

这天吃完午饭,临时起意,带媳妇溜溜大街,见识下我们的大街。

小时候,整天在这条街上跑来跑去。

解决Golang使用go get安装包后找不到可执行文件的问题

背景

编译流水线代码

go get google.golang.org/protobuf/cmd/protoc-gen-go@latest

protoc -I=./zzz --proto_path=./xx --go_out=./abc --go_opt=paths=xx.proto

...

go build -o xxx

在go升级到1.20.1版本后,执行报错。

protoc-gen-go: program not found or is not executable

解决

Starting in Go 1.17, installing executables with go get is deprecated. go install may be used instead.

In a future Go release, go get will no longer build packages; it will only be used to add, update, or remove dependencies in go.mod. Specifically, go get will act as if the -d flag were enabled.

修正Hugo的JSON Feed格式

问题背景

前几天在Planet里follow自己的web3博客,遇到下面的错误。

PlanetFeedError

经过Livid大佬提醒,说是网站的JSON Feed不是标准格式导致的。

因为我的已经修正没法截图,这里以dvel的博客举例,格式类似如下。

[
  {
    "content": "用 ChatGPT 写一些小脚本真是太方便了。\nGPT-4 发布后试了试,还是蛮不错的,代码是 ChatGPT 生成的。\n几个来回就可以编写一个能正常使用的油猴脚本:\n(略,HTML 代码) 在 https://chdbits.co/bakatest.php 有如上内容。 我要为这个网页编写一个油猴脚本。 通过自动获取 ChatGPT 的 API 来解析此问题的答案,供用户参考。 将内容输出到 `#outer &gt; h1` 的下面,同时输出你提取到的问题内容和答案,以便我看看你是否提取正确。 获取错啦。 问题的获取路径是 `#outer &gt; form &gt; table &gt; tbody &gt; tr:nth-child(1) &gt; td` 选项的获取路径是 `#outer &gt; form &gt; table &gt; tbody &gt; tr:nth-child(2) &gt; td` 使用这个 API: ``` curl https://api.openai.com/v1/chat/completions \\ -H &#39;Content-Type: application/json&#39; \\ -H &#39;Authorization: Bearer YOUR_API_KEY&#39; \\ -d &#39;{ &#34;model&#34;: &#34;gpt-3.5-turbo&#34;, &#34;messages&#34;: [{&#34;role&#34;: &#34;user&#34;, &#34;content&#34;: &#34;Say this is a test!&#34;}], &#34;temperature&#34;: 0.7 }&#39; ``` 响应格式为: ``` { &#34;id&#34;:&#34;chatcmpl-abc123&#34;, &#34;object&#34;:&#34;chat.completion&#34;, &#34;created&#34;:1677858242, &#34;model&#34;:&#34;gpt-3.5-turbo-0301&#34;, &#34;usage&#34;:{ &#34;prompt_tokens&#34;:13, &#34;completion_tokens&#34;:7, &#34;total_tokens&#34;:20 }, &#34;choices&#34;:[ { &#34;message&#34;:{ &#34;role&#34;:&#34;assistant&#34;, &#34;content&#34;:&#34;\\n\\nThis is a test!&#34; }, &#34;finish_reason&#34;:&#34;stop&#34;, &#34;index&#34;:0 } ] } ``` 它没有最近的互联网数据,所以还是需要把 API 的使用方式发给它。\n然后它就帮我写好了,我不用复习 JavaScript,不用看油猴脚本的教程和文档,也不用查 @grant 等等标记是干嘛的。\n可以再继续要求它改进一些,比如换个输出位置,优化 prompt,自动选中正确回答,支持单选题和多选题等等。\n效果展示:\n安装: https://greasyfork.org/zh-CN/scripts/461944-chd-quiz-answer\n",
    "permalink": "https://dvel.me/posts/chd-quiz-answer/",
    "summary": "用 ChatGPT 写一些小脚本真是太方便了。\nGPT-4 发布后试了试,还是蛮不错的,代码是 ChatGPT 生成的。\n几个来回就可以编写一个能正常使用的油猴脚本:\n(略,HTML 代码) 在 https://chdbits.co/bakatest.php 有如上内容。 我要为这个网页编写一个油猴脚本。 通过自动获取 ChatGPT 的 API 来解析此问题的答案,供用户参考。 将内容输出到 `#outer &gt; h1` 的下面,同时输出你提取到的问题内容和答案,以便我看看你是否提取正确。 获取错啦。 问题的获取路径是 `#outer &gt; form &gt; table &gt; tbody &gt; tr:nth-child(1) &gt; td` 选项的获取路径是 `#outer &gt; form &gt; table &gt; tbody &gt; tr:nth-child(2) &gt; td` 使用这个 API: ``` curl https://api.openai.com/v1/chat/completions \\ -H &#39;Content-Type: application/json&#39; \\ -H &#39;Authorization: Bearer YOUR_API_KEY&#39; \\ -d &#39;{ &#34;model&#34;: &#34;gpt-3.5-turbo&#34;, &#34;messages&#34;: [{&#34;role&#34;: &#34;user&#34;, &#34;content&#34;: &#34;Say this is a test!",
    "title": "CHD 油猴脚本:每日签到自动答题"
  },
  ...
]

下面是一个JSON Feed的示例,详细规范见jsonfeed.org

我的学车之路

之前在2022年终总结提到过,我在练车考驾照。

就在昨天,终于拿证了。👏👏👏

咱也是可以上路开车的人了,虽然比别人晚了快10年才拿证。🐶

2022年6月11日,在海淀驾校报名,周末连续班,报名费5380元。

2022年10月12日,科目一考试通过。

2022年10月22日,科目二模拟驾驶。

2022年11月13日,科目二第一次上车练习。

2022年11月24日,疫情严重,驾校发通知,自11月25日暂停培训。

2023年2月4日,年后驾校恢复培训,继续科目二练车。

2023年2月13日,科目二考试通过。

2023年3月11日,科目三上路练习。

2023年3月23日,上午科目三考试通过,下午科目四考试通过。
考试的时候,早上遇到临时交通管制,一直到9点40才开考。
考完回来,班车上的人说又管制不能考了。
班车拉回驾校,剩下的人中午加班考试。

终于不用再5点半起床赶班车了。🥱

将博客部署到星际文件系统(IPFS)

在这篇文章,我将会介绍如何利用Github Actionshugo博客自动部署到IPFS上,并通过自定义域名访问IPFS上的文件。

IPFS(InterPlanetary File System)中文称为星际文件系统,是一个旨在实现文件的分布式存储、共享和持久化的网络传输协议。

新冠疫情后的第一个春节

下面的内容是由chatGPT润色生成的。

AI太强大了 😂

当我还是个孩子的时候,在看春节晚会时,总会有节目介绍那些不能回家过年的人。

但我从未想过,等我长大后,我也会成为其中的一员。

第一次清理键盘

19年生日的时候,媳妇送了一款flico的机械键盘。

这次搬家后,想着年前清理下键盘,实在是太脏了。

周五下班,带上键盘回家。

2022年终总结

2022年已经过去1周多了,记录一下我的2022年。

疫情

2022年,是新冠疫情的第三年,也是切身感受到的一年。

3月22日晚,8点半和同事刚上13号线地铁。

累计布局偏移修复方案改进 —— 自动生成图片宽高

本站已不再采用本方案,新方案见使用Hugo实现响应式和优化的图片

遗留的问题

上一篇文章讲了我是如何解决博客累计布局偏移的问题,但是这个方案存在一个很大的问题。

手动输入每张图片的宽高

这就要求每次插入图片后,需要手动查看图片宽高,修改插入代码,导致整个流程变得繁琐,无法自动化。

将博客部署到Cloudflare Pages

目前博客是部署到了Github Pages上,具体实现见博客架构说明

缘由

Github Pages部署有一个问题,就是不支持HSTS

HTTP Strict Transport Security(通常简称为HSTS)是一个安全功能,它告诉浏览器只能通过 HTTPS 访问当前资源,而不是HTTP。

奥林匹克公园向日葵之旅

媳妇有事回老家了,这两天自己带娃。

小区群里有人说奥林匹克公园的向日葵开了,适合拍照。

正好周六多云,没有太阳,出门遛娃。

带上我好久不用的相机,省得发霉了。

记第二次洗牙

最近刷牙的时候,牙龈总是出血。

距离上一次洗牙,已经有好几年了,感觉又该去洗一下牙了。

上次跟媳妇两个人,在小区外面的私人诊所洗的,俩人花了1000多块钱。

记录2022年海淀幼升小

20220525202612

18年的热点新闻,纳税千万孩子无法在北京上学。

一直听说外地人在北京上学难,今年娃到了上小学的年纪,也算真实的体验了一把上学的难。

Golang解析json的一个问题

业务模块从php迁移到golang下了,最近遇到一个golang下json解析的问题:

请求接口,按返回包字段判断请求成功与否。

伪代码如下:

package main

import (
	"encoding/json"
	"fmt"
)

type Response struct {
	Code int    `json:"code"`
	Msg  string `json:"msg"`
}

func main() {
	// 场景1,返回包符合接口要求
	str := `{"code":100,"msg":"failed"}`
	var res Response
	json.Unmarshal([]byte(str), &res)
	fmt.Printf("res=%+v\n", res)
    // 解析正确,符合预期
	// res={Code:100 Msg:failed}

	// 场景2,返回包不符合接口要求,缺少相关字段
	str = `{"retCode":100,"retMsg":"failed"}`
	var res1 Response
	json.Unmarshal([]byte(str), &res1)
	fmt.Printf("res=%+v\n", res1)
    // 解析错误,不符合预期
	// res={Code:0 Msg:}
}

这里由于接口地址配置错误,导致请求到其他接口,返回包不符合协议要求。

疫情下的生活

20220520-192500@2x

不知不觉,北京这一波疫情已经一个月了,目前还是每天50例左右新增。

昨天看新闻,基本没有社会面新增了,感觉要解封了。

没想到今天直接被打脸,封控升级了。

整理下博客的一些调整

新域名上线一段时间了,通过Google Search Console发现了一些问题,整理下最近进行的一些调整。

  1. 更新主题版本,展示文章tag标签 通过对比主题作者的网站,发现使用的不是最新代码。

疫情下的五一假期

五一假期前一周,北京疫情又起,说是已经隐蔽传播一周了。

当天晚上大家就开始屯货了,晚上看着APP里可买的东西一点点没了。

说实话,出现几粒确诊没有慌,这么抢购搞的有点心慌了,也下单买了点东西。

自己动手,更换thinkpad x1硬盘

电脑突然没法用了,提示"A disk read error occurred"的错误。

491650584526_.pic

多次重启也不行,感觉是硬盘挂了。

机器去年过保了,之前有过在售后维护的经历,费用不低,这次决定自己动手。

二刷百望山

又是周末,娃约了小伙伴一起爬山。

百望山,二刷走起。

约好了9点半门口见面,早上睁眼8点了,赶紧起床洗漱吃饭。

出门晚了,还打不到车,快10点才到。

小伙伴和人爸爸已经先爬上去了,带着娃一路小跑,20分钟从大门爬到山上。

带娃游颐和园

上周的北海之行,本来是想划船的,可惜人太多没有划成,答应娃这周末带她去划船。

周六7点准时起床,得早点去省得人多排队。

8点半吃完饭洗漱完出发,特意带娃坐了一趟双层公交车 —— 二楼第一排观光区。

博客架构说明

在拿到liudon.com域名前,手中已有两个域名:

  • liudon.org
  • liudon.xyz

两套域名说明

liudon.org已经不再更新,仅作归档使用。 liudon.xyz当时是静态博客流行,尝鲜使用。

难得的清明假期

前面有写到,被隔离了一周,好在赶在假期开始前解除了隔离。

趁着这次难得的假期,外出放松一下。

  1. 爬百望山。

    娃是第一次爬山,百望山不高,适合带娃体验爬山,我也从13、14年之后没再爬过山了。

被隔离的一周

从没有想过疫情会离自己这么近,记录一下。

周一的时候说是有确诊同学来过公司,下午组织全员核酸,做完核酸立马回家。

周二早上全员核酸阴性,继续到公司上班。

mysql中字符串和整型自动转换的问题

表结构如下

desc info;
+-------+-----------------+------+-----+---------+----------------+
| Field | Type            | Null | Key | Default | Extra          |
+-------+-----------------+------+-----+---------+----------------+
| id    | int(8) unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(20)     | YES  |     | NULL    |                |
+-------+-----------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

执行sql.

insert into info values ('', 'xxx');
insert into info values ('', 'yyy');

查询记录.

select * from info;
+----+------+
| id | name |
+----+------+
|  1 | xxx  |
|  2 | yyy  |
+----+------+
2 rows in set (0.00 sec)

执行下面sql.

一次惊心动魄的Mysql更新操作

问题描述

# 表结构
MySQL > desc user_packages;
+----------------+---------------------+------+-----+---------------------+----------------+
| Field          | Type                | Null | Key | Default             | Extra          |
+----------------+---------------------+------+-----+---------------------+----------------+
| up_id          | bigint(20) unsigned | NO   | PRI | NULL                | auto_increment |
| start_date     | date                | NO   |     | NULL                |                |
| end_date       | date                | NO   |     | NULL                |                |
| up_created     | datetime            | NO   | MUL | 0000-00-00 00:00:00 |                |
| up_updated     | datetime            | NO   |     | 0000-00-00 00:00:00 |                |
+----------------+---------------------+------+-----+---------------------+----------------+
5 rows in set (0.00 sec)

MySQL > select * from user_packages limit 5;
+-------+------------+------------+
| up_id | start_date | end_date   |
+-------+------------+------------+
|   185 | 2018-04-01 | 2018-06-30 |
|   186 | 2018-04-01 | 2018-06-30 |
|   187 | 2018-04-01 | 2018-06-30 |
|   188 | 2018-04-01 | 2018-06-30 |
|   189 | 2018-04-01 | 2018-06-30 |
+-------+------------+------------+
5 rows in set (0.00 sec)

操作过程

需要更新某条记录的end_date字段,执行sql如下:

PHP7.2编译安装后没有php.ini文件的问题

下载PHP7.2源码,编译安装。

[root@VM_73_135_centos ~/swoole-src-4.4.12]# php -v
PHP 7.2.25 (cli) (built: Nov 26 2019 19:33:23) ( NTS )
Copyright (c) 1997-2018 The PHP Group
Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
[root@VM_73_135_centos ~/swoole-src-4.4.12]# 

安装Swoole。

phpize && \
./configure && \
make && make install

安装完,准备修改php.ini文件,结果没找到。

检测网站支持的SSL/TLS协议版本

Chrome 72及以上版本不支持TLS 1.0和TLS 1.1,访问TLS 1.0或1.1证书的站点会告警,但不阻止用户访问站点。

为了解决Chrome的这个问题,今天升级了下Nginx的TLS协议版本,这里记录一下如何检测支持的协议版本。

十一假期经历

今年的十一火车票非常难抢,12306的候补订单,一直等到时间截止也没订上票。

只好请了2天假,提前回家了,给自己也放个假休息一下。


回家的几个经历:

  1. 家里的老洗衣机光荣退休了,年龄比我都要大,爸妈舍不得换一直用着。

Swoft 框架运行分析(五) —— ConsoleProcessor模块分析

这里以Swoft启动http server为例。

php bin/swoft http:start

执行上述命令,启动http server。

在前面第一篇文章的时候,提到了如何启动http服务。

今天我们就来看一下http服务是如何启动的,具体实现就在ConsoleProcess这个模块。

Swoft 框架运行分析(四) —— EventProcessor模块分析

今天我们来看一下EventProcessor的实现。

/**
    * Handle event register
    * @return bool
    */
public function handle(): bool
{
    if (!$this->application->beforeEvent()) {
        CLog::warning('Stop event processor by beforeEvent return false');
        return false;
    }

    /** @var EventManager $eventManager */
    $eventManager = bean('eventManager');
    [$count1, $count2] = ListenerRegister::register($eventManager);

    CLog::info('Event manager initialized(%d listener, %d subscriber)', $count1, $count2);

    // Trigger a app init event
    Swoft::trigger(SwoftEvent::APP_INIT_COMPLETE);

    return $this->application->afterEvent();
}

获取eventManagerBean实例,对应为Swoft\Event\Manager\EventManager类。

一个git submodule update引发的问题

背景

1月份的时候,用hugo搭了这套博客系统。

本机写md文件,更新到github,然后通过travis-ci自动发布。

jane主题是通过git submodule引入的,.gitmodules文件内容。

一个Curl的耗时长的问题

发现某个接口请求很慢,但是后端确认接口是很快的。

在机器上通过shell执行curl命令,确实很快,但是PHP代码里请求又确实很慢。

业务里用到了Requests这个库,一开始以为是这个库导致的问题。

Swoft 框架运行分析(三) —— BeanProcessor模块分析

今天讲一下BeanProcessor模块,先看一下handle方法实现。

/**
    * Handle bean
    *
    * @return bool
    * @throws ReflectionException
    * @throws AnnotationException
    */
public function handle(): bool
{
    if (!$this->application->beforeBean()) {
        return false;
    }

    $handler     = new BeanHandler();
    $definitions = $this->getDefinitions();
    $parsers     = AnnotationRegister::getParsers();
    $annotations = AnnotationRegister::getAnnotations();

    BeanFactory::addDefinitions($definitions);
    BeanFactory::addAnnotations($annotations);
    BeanFactory::addParsers($parsers);
    BeanFactory::setHandler($handler);
    BeanFactory::init();

    /* @var Config $config*/
    $config = BeanFactory::getBean('config');

    CLog::info('config path=%s', $config->getPath());
    CLog::info('config env=%s', $config->getEnv());

    $stats = BeanFactory::getStats();

    CLog::info('Bean is initialized(%s)', SwoftHelper::formatStats($stats));

    return $this->application->afterBean();
}

先通过getDefinitions方法获取所有的Bean定义。

Swoft 框架运行分析(二) —— AnnotationProcessor模块分析

上一篇介绍了,SwoftApplication里定义了6个Processor对象。

protected function processors(): array
    {
        return [
            new EnvProcessor($this),
            new ConfigProcessor($this),
            new AnnotationProcessor($this),
            new BeanProcessor($this),
            new EventProcessor($this),
            new ConsoleProcessor($this),
        ];
    }

所有的Processor实现都在framework\src\Processor目录下。

Swoft 框架运行分析(一)

Swoft 是一款基于 Swoole 扩展实现的 PHP 微服务协程框架。

以前一直都是用的原生swoole框架,最近有时间研究了下衍生的Swoft框架。

刚开始看的时候,感觉自己像个原始人,完全看不懂。

BCMath 与 科学计数

代码如下

<?php
echo 9.99997600 + 2.4E-5;
echo "\n===\n";
echo bcadd(9.99997600, 2.4E-5, 8);

结果为

10
===
9.99997600

问了朋友,查了各种资料,终于在PHP手册里发现了这段话。

Caution Passing values of type float to a BCMath function which expects a string as operand may not have the desired effect due to the way PHP converts float values to string, namely that the string may be in exponential notation (which is not supported by BCMath), and that the decimal separator is locale dependent (while BCMath always expects a decimal point).

Flink Could Not Resolve Resourcemanager Address

什么是Flink。

Apache Flink® - Stateful Computations over Data Streams

Flink安装参考(官方文档)[https://ci.apache.org/projects/flink/flink-docs-release-1.7/tutorials/local_setup.html]。

关于本站

大家好,欢迎来到我的博客。

建站缘由

大学期间,被人忽悠报了一个计算机培训班,误打误撞的进入了互联网行业。

11年在网友的帮助下,用wordPress搭建了博客,随即开始了我的博主生涯。

2019,新开始

从2011年开始写博客,博客程序从WordPress换成Typecho。 早就有想法换成静态博客,一直没时间搞。

2019年了,新年新气象,用hugo + github pages搞了个新博客。

❌