Linux安装go及环境配置教程

Linux安装go及环境配置教程

1. ​​下载Go安装包​

  • 访问Go官方下载页面选择适合Linux的版本(如go1.22.5.linux-amd64.tar.gz,版本可能更新)。

使用wget直接下载(以Go 1.22.5为例):

wget https://mirrors.aliyun.com/golang/go1.24.5.linux-amd64.tar.gz 
在这里插入图片描述

2. ​​解压安装包​

  • ​权限问题​​:若无法写入/usr/local,可解压到用户目录(如~/go),但需额外配置环境变量。

将安装包解压到/usr/local目录(推荐):

sudotar -C /usr/local -xzf go1.24.5.linux-amd64.tar.gz 

3. ​​配置环境变量​

    • ​说明​​:

使配置生效:

source ~/.bashrc 

PATH:添加Go可执行文件路径(/usr/local/go/bin)。
* GOPATH:Go工作目录(默认~/go),存放第三方包和编译后的二进制文件。

在这里插入图片描述

在文件末尾添加以下内容:

exportPATH=$PATH:/usr/local/go/bin exportGOPATH=$HOME/go exportPATH=$PATH:$GOPATH/bin 

编辑Shell配置文件(如~/.bashrc~/.zshrc~/.profile):

vim ~/.bashrc 

4. ​​验证安装​

检查Go版本:

go version 

若如下图所示,输出类似go version go1.24.5 linux/amd64,说明安装成功。

5. ​​测试Go程序​

创建并运行简单的Hello World程序:

mkdir -p ~/go/src/hello cd ~/go/src/hello nano hello.go 

写入以下代码:

package main import"fmt"funcmain(){ fmt.Println("Hello, Go!")}

保存后运行:

go run hello.go

若输出Hello, Go!,则环境配置成功。

6. ​​可选配置​

​使用Go Modules​​(Go 1.11+默认支持):

go mod init example.com/hello 

生成go.mod文件管理依赖。

​国内用户代理设置​​(解决下载依赖慢):

go env -w GOPROXY=https://goproxy.cn,direct 

7. ​​卸载Go​

删除Go目录并清理环境变量:

sudorm -rf /usr/local/go 

编辑~/.bashrc删除相关配置。

常见问题解决

  • go: command not found​:检查PATH是否包含/usr/local/go/bin,并重新加载配置。
  • ​权限问题​​:使用sudo或解压到用户目录。

通过以上步骤,您可以在Linux系统上完成Go语言的安装和配置。如需更详细的版本管理,可参考工具如gvm(Go Version Manager)。

Read more

RabbitMQ如何成为分布式系统的“神经中枢“?——从安装部署到C++调用实战的完整流程,带你体验它的奥妙所在!​

RabbitMQ如何成为分布式系统的“神经中枢“?——从安装部署到C++调用实战的完整流程,带你体验它的奥妙所在!​

文章目录 * 本篇摘要 * ①·RabbitMq(轻量级消息队列中间件) 介绍 * RabbitMQ 是什么? * 核心功能与特点 * 1. **核心功能** * 2. **核心优势** * RabbitMQ 的核心概念 * 1. **生产者(Producer)** * 2. **消费者(Consumer)** * 3. **队列(Queue)** * 4. **交换机(Exchange)** * 5. **绑定(Binding)** * 工作流程(以 Direct 交换机为例) * 常见应用场景 * RabbitMQ 与相关技术对比 * 图像理解 * 总结一句话 * ②·RabbitMq 安装教程 * RabbitMq安装 * **1. 安装 RabbitMQ** * **2. 启动 & 检查状态** * **3. 创建管理员用户(

By Ne0inhk
SkyWalking - Kafka _ RabbitMQ 消息链路追踪支持

SkyWalking - Kafka _ RabbitMQ 消息链路追踪支持

👋 大家好,欢迎来到我的技术博客! 📚 在这里,我会分享学习笔记、实战经验与技术思考,力求用简单的方式讲清楚复杂的问题。 🎯 本文将围绕SkyWalking这个话题展开,希望能为你带来一些启发或实用的参考。 🌱 无论你是刚入门的新手,还是正在进阶的开发者,希望你都能有所收获! 文章目录 * SkyWalking - Kafka / RabbitMQ 消息链路追踪支持 🚀 * 为什么需要消息链路追踪?🤔 * SkyWalking 核心概念回顾 🔍 * Kafka 链路追踪支持 🐘 * 1. 自动探针(推荐)✅ * 前提条件 * 工作原理 * Java 代码示例(无需修改业务代码!) * 验证追踪效果 * 2. 手动埋点(高级场景)🛠️ * 添加依赖 * 手动注入上下文(Producer) * 手动提取上下文(Consumer) * RabbitMQ 链路追踪支持 🐇 * 工作原理 * Java 代码

By Ne0inhk
KWDB 运维实战:拒绝数据孤岛!用 SQL 打通 Metrics 与 CMDB 的“任督二脉”

KWDB 运维实战:拒绝数据孤岛!用 SQL 打通 Metrics 与 CMDB 的“任督二脉”

在互联网大厂,服务器监控(AIOps)是基础设施的命脉。一旦核心数据库或网关宕机,每分钟的损失可能高达数百万。 传统的监控方案(如 Zabbix、Prometheus)在面对海量指标时各有痛点:Zabbix 擅长告警但历史数据存储能力弱;Prometheus 查询语言(PromQL)学习曲线陡峭且不易与业务数据(如 CMDB)进行关联分析。 运维人员真正需要的是:既能像 Prometheus 一样吞吐海量时序数据,又能像 MySQL 一样用标准 SQL 进行复杂关联查询。 本文将带你体验如何用 KWDB 3.1.0 搭建一个轻量级但高性能的 服务器监控系统,用一个数据库搞定“指标存储”与“资产管理”。 * 场景设定: 监控 500 台服务器的 CPU、内存、磁盘 IO 和网络流量。 * 核心挑战:

By Ne0inhk
直击复杂 SQL 瓶颈:基于代价的连接条件下推技术落地

直击复杂 SQL 瓶颈:基于代价的连接条件下推技术落地

一、引言 在数据库理论的学习过程中,我们常常接触到简洁优美的SQL示例——单表查询、简单连接、基础过滤,这些案例清晰地展示了关系代数的基本原理。然而,当我们步入真实的业务系统,面对的SQL语句往往如同缠绕的线团:公用表表达式(CTE)层层嵌套,子查询彼此交织,窗口函数与聚集计算随处可见。 这种复杂性并非开发人员的炫技,而是业务逻辑的自然映射。遗憾的是,这种为提升可读性而组织的SQL结构,却给查询优化器带来了严峻考验。在众多性能瓶颈中,有一个问题尤为突出:高选择性的连接条件无法穿透复杂的子查询结构,导致数据过滤发生在错误的时间点。本文将深入探讨这一问题的本质,并介绍一种基于代价模型的连接条件下推解决方案,展示如何让优化器既懂“安全”,又知“成本”。 二、性能困境:过滤迟到的代价 2.1 真实场景的切面分析 在大量客户业务系统中,一种常见的SQL编写模式反复出现:开发人员习惯先在子查询或CTE中完成复杂的预处理逻辑——去重、排序、窗口计算,然后再将这些预处理结果与其它表进行连接,最后施加过滤条件。从业务语义角度看,这种写法清晰自然;但从执行效率角度看,却暗藏危机。 考虑

By Ne0inhk