Golang database/sql 数据库断线自动重连机制解析
最近有个交接服务的数据库要升级版本,升级最后切换瞬间会有一个闪断。
这里业务侧需要确保有自动重连机制,否则会影响服务。
因为是交接的服务,得通过代码再确认一下。
最近有个交接服务的数据库要升级版本,升级最后切换瞬间会有一个闪断。
这里业务侧需要确保有自动重连机制,否则会影响服务。
因为是交接的服务,得通过代码再确认一下。
重现代码:
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连接。
去年10月底,考虑到老的绿源电动车已经骑了5年,电池越来越不行,马上要冬天了,考虑换个新电动车。
到各个品牌店里转了一圈,发现都没有车子,说是新规的缘故,要到11月份才能有新车。
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。
昨天像往常一样打开博客,发现评论没有加载出来。
一开始以为是手机网络问题,用电脑复现了一下,发现twikoo的js访问报错了。
细心的朋友可能会发现,我的博客图片都带上了水印。
经过博客被恶意镜像这个事情后,我一直在思考如何防止内容被恶意盗用,尤其是博客里的一些图片。
在当Hugo遇上AVIF,优化图片加载这篇文章里,使用了ImageMagick工具做了图片压缩。
当时文章最后说留了个坑,其实就是今天的这篇内容,利用ImageMagick自动给图片添加水印。
Livid大佬新搞了个支持Solana的IPFS/IPNS网关,了解到还有一个.sol
的web3域名。
Solana域名服务(SNS)的目标是提供一种去中心化且可负担的方式,将域名(.sol)和链上数据连接起来。这些链上数据可以是SOL地址、 IPFS CID、图片、文本、或者任何其它的东西。
五一的时候带娃骑过南边这段,网上查了说北边这段不好骑,难得2号下午有空,决定先自己走一遍看看。
从家附近的奥北森林公园开始,骑行到沙河水库,整个行程近30公里,耗时3个小时左右。
早上5点半起床洗漱,6点出门打车直奔清河站,6点50的火车S515清河-雁栖湖。
虽然坐地铁经常路过清河站,但还是第一次来清河站坐车。
我们提前20分钟到的车站,已经开始排队了。
这篇文章会介绍基于Github Workflow使用ImageMagick生成AVIF图片,来优化Hugo站点的加载速度。
上周末在搭建个人锻炼页面时,遇到个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
核心逻辑就是上面这段。
中午的时候,突然收到一条消息,打开一看,提示我的Google Adsense
审核通过了。
偶然发现Google Adsense
里居然有40美金,想起来是之前老博客加的广告。
本文会介绍如何接入filebase
的Names(IPNS)服务,使你的IPFS
站点持久在线。
周末更新博客时,发现workflow的上传IPFS任务执行失败了。
$ 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
同样的代码在本机编译就没问题,但是放到流水线里编译就报上面的错误。
4月底的时候,Livid大佬提醒,Cloudflare
应该是调整了IPFS Gateway
网关策略,我的IPFS镜像博客无法访问了。
没查到Cloudflare
的调整说明,不过还好IPFS
官方也提供了公共网关gateway.ipfs.io
,将域名解析改到官网网关。
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
浏览器报错
什么是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
下实现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咨询了一下,说是可以内地见证方式修改密码,只需要带上港澳通行证和身份证即可。
这是当前的博客架构,文件保存在Github
仓库,通过Cloudflare Page
提供访问。
众所周知,在国内,Cloudflare
的CDN属于反向加速,平均耗时在1.5s左右。
记录暴雪下普通打工人的生活。
北京的雪已经连着下了两天了。
12月11日,也是因为下雪,晚上打车打到10点半才叫到车。
所以这次下雪后,晚上就早走了。
继续我们的博客优化之旅,本篇内容我们将介绍如何使用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
很慢,同时还面临着各种广告屏蔽插件拦截。
对于一个新站点来说,总是想着能让搜索引擎快点收录网站内容。
今天,我们就来介绍一种利用Google Indexing API
接口,通过Github Actions
实现部署时通知Google
抓取页面内容。
在本篇文章里,我会介绍如何在Netlify上部署Twikoo评论系统,如何接入到静态博客Hugo,以及如何实现Twikoo系统版本自动更新。
2024年7月30日更新:因为Github接口策略调整,原有的匿名通过接口获取版本号方法失效,已更改为带token方式请求接口获取版本号,详见workflow里Get twikoo version步骤配置。
上次洗完牙后,还是不时有出血的情况。
前段时间更是出现牙龈劈开一块肉,特别容易塞东西的情况。
于是,又跑到医院来看牙了。
医生检查后,说是牙周病,需要牙周刮治,要约到8月份了。
编译流水线代码
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.
前几天在Planet里follow自己的web3博客,遇到下面的错误。
经过Livid大佬提醒,说是网站的JSON Feed不是标准格式导致的。
因为我的已经修正没法截图,这里以dvel的博客举例,格式类似如下。
[
{
"content": "用 ChatGPT 写一些小脚本真是太方便了。\nGPT-4 发布后试了试,还是蛮不错的,代码是 ChatGPT 生成的。\n几个来回就可以编写一个能正常使用的油猴脚本:\n(略,HTML 代码) 在 https://chdbits.co/bakatest.php 有如上内容。 我要为这个网页编写一个油猴脚本。 通过自动获取 ChatGPT 的 API 来解析此问题的答案,供用户参考。 将内容输出到 `#outer > h1` 的下面,同时输出你提取到的问题内容和答案,以便我看看你是否提取正确。 获取错啦。 问题的获取路径是 `#outer > form > table > tbody > tr:nth-child(1) > td` 选项的获取路径是 `#outer > form > table > tbody > tr:nth-child(2) > td` 使用这个 API: ``` curl https://api.openai.com/v1/chat/completions \\ -H 'Content-Type: application/json' \\ -H 'Authorization: Bearer YOUR_API_KEY' \\ -d '{ "model": "gpt-3.5-turbo", "messages": [{"role": "user", "content": "Say this is a test!"}], "temperature": 0.7 }' ``` 响应格式为: ``` { "id":"chatcmpl-abc123", "object":"chat.completion", "created":1677858242, "model":"gpt-3.5-turbo-0301", "usage":{ "prompt_tokens":13, "completion_tokens":7, "total_tokens":20 }, "choices":[ { "message":{ "role":"assistant", "content":"\\n\\nThis is a test!" }, "finish_reason":"stop", "index":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 > h1` 的下面,同时输出你提取到的问题内容和答案,以便我看看你是否提取正确。 获取错啦。 问题的获取路径是 `#outer > form > table > tbody > tr:nth-child(1) > td` 选项的获取路径是 `#outer > form > table > tbody > tr:nth-child(2) > td` 使用这个 API: ``` curl https://api.openai.com/v1/chat/completions \\ -H 'Content-Type: application/json' \\ -H 'Authorization: Bearer YOUR_API_KEY' \\ -d '{ "model": "gpt-3.5-turbo", "messages": [{"role": "user", "content": "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点半起床赶班车了。🥱
在这篇文章,我将会介绍如何利用Github Actions
将hugo
博客自动部署到IPFS
上,并通过自定义域名访问IPFS
上的文件。
IPFS(InterPlanetary File System)中文称为星际文件系统,是一个旨在实现文件的分布式存储、共享和持久化的网络传输协议。
下面的内容是由chatGPT润色生成的。
AI太强大了 😂
当我还是个孩子的时候,在看春节晚会时,总会有节目介绍那些不能回家过年的人。
但我从未想过,等我长大后,我也会成为其中的一员。
通过WebPageTest页面测试,发现一个/cdn-cgi/scripts/5c5dd728/cloudflare-static/email-decode.min.js
的文件请求,影响到了页面渲染。
本站已不再采用本方案,新方案见使用Hugo实现响应式和优化的图片
上一篇文章讲了我是如何解决博客累计布局偏移的问题,但是这个方案存在一个很大的问题。
手动输入每张图片的宽高
这就要求每次插入图片后,需要手动查看图片宽高,修改插入代码,导致整个流程变得繁琐,无法自动化。
此文已过期,优化方案参考累计布局偏移修复方案改进 —— 自动生成图片宽高.
7月份将博客部署由Github
迁移到Cloudflare
后,开始关注博客的性能问题。
偶然看到苏卡卡大佬的CLS优化文章,拿自己博客也测试了下,发现也存在同样的问题。
目前博客是部署到了Github Pages
上,具体实现见博客架构说明。
Github Pages
部署有一个问题,就是不支持HSTS
。
HTTP Strict Transport Security(通常简称为HSTS)是一个安全功能,它告诉浏览器只能通过 HTTPS 访问当前资源,而不是HTTP。
媳妇有事回老家了,这两天自己带娃。
小区群里有人说奥林匹克公园的向日葵开了,适合拍照。
正好周六多云,没有太阳,出门遛娃。
带上我好久不用的相机,省得发霉了。
18年的热点新闻,纳税千万孩子无法在北京上学。
一直听说外地人在北京上学难,今年娃到了上小学的年纪,也算真实的体验了一把上学的难。
业务模块从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:}
}
这里由于接口地址配置错误,导致请求到其他接口,返回包不符合协议要求。
新域名上线一段时间了,通过Google Search Console
发现了一些问题,整理下最近进行的一些调整。
更新主题版本,展示文章tag标签 通过对比主题作者的网站,发现使用的不是最新代码。
电脑突然没法用了,提示"A disk read error occurred"的错误。
多次重启也不行,感觉是硬盘挂了。
机器去年过保了,之前有过在售后维护的经历,费用不低,这次决定自己动手。
表结构如下
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 > 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如下:
关于取消住房公积金提取业务纸质申请表及部分业务网上办结的公告
时间:2020年01月08日
来源:http://gjj.beijing.gov.cn/web/zwgk/_300583/zxzysx/675803/index.html
下载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
文件,结果没找到。
Chrome 72及以上版本不支持TLS 1.0和TLS 1.1,访问TLS 1.0或1.1证书的站点会告警,但不阻止用户访问站点。
为了解决Chrome的这个问题,今天升级了下Nginx的TLS协议版本,这里记录一下如何检测支持的协议版本。
这里以Swoft启动http server为例。
php bin/swoft http:start
执行上述命令,启动http server。
在前面第一篇文章的时候,提到了如何启动http服务。
今天我们就来看一下http服务是如何启动的,具体实现就在ConsoleProcess
这个模块。
今天我们来看一下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();
}
获取eventManager
的Bean
实例,对应为Swoft\Event\Manager\EventManager
类。
1月份的时候,用hugo
搭了这套博客系统。
本机写md文件,更新到github
,然后通过travis-ci
自动发布。
jane主题是通过git submodule
引入的,.gitmodules
文件内容。
发现某个接口请求很慢,但是后端确认接口是很快的。
在机器上通过shell执行curl命令,确实很快,但是PHP代码里请求又确实很慢。
业务里用到了Requests
这个库,一开始以为是这个库导致的问题。
今天讲一下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定义。
上一篇介绍了,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 是一款基于 Swoole 扩展实现的 PHP 微服务协程框架。
以前一直都是用的原生swoole框架,最近有时间研究了下衍生的Swoft框架。
刚开始看的时候,感觉自己像个原始人,完全看不懂。
代码如下
<?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。
Apache Flink® - Stateful Computations over Data Streams
Flink安装参考(官方文档)[https://ci.apache.org/projects/flink/flink-docs-release-1.7/tutorials/local_setup.html]。
今天安装hugofy的包时,一直遇到"There Are No Packages Available for Installation"的错误。 按网上的教程,配置host,配置代理都不起作用。