推荐在nixos上使用声明式包管理部署golang环境。最推荐的方式是根据需求选择全局安装、nix-shell临时环境或flakes配置开发环境:1. 配置environment.systempackages添加go实现全局安装,如go_1_20;2. 使用nix-shell按需加载go环境,在shell.nix中指定buildinputs = [ pkgs.go_1_20 ];3. 配合flakes在flake.nix定义开发环境,通过nix develop进入;4. 设置goproxy=https://goproxy.cn,direct提升模块下载速度,可将其写入shellhook。以上方式均支持版本灵活切换并确保环境一致性。

在NixOS上部署Golang环境,最推荐的方式是使用系统的声明式包管理方案。这种方式不仅符合NixOS的设计理念,还能确保你的开发环境可复现、易维护。

配置environment.systemPackages添加Go
如果你只需要全局安装某个版本的Go,可以直接在configuration.nix中添加:

environment.systemPackages = with pkgs; [ go_1_20 ];
这里以Go 1.20为例,你也可以换成其他版本如go_1_21。保存后执行sudo nixos-rebuild switch即可生效。
立即学习“go语言免费学习笔记(深入)”;
这个方法适合那些希望整个系统层面都可用Go的情况,比如CI服务器或统一开发环境。

使用nix-shell临时进入带Go的环境
对于开发者来说,更常见的做法是通过nix-shell按需加载Go环境。新建一个shell.nix文件内容如下:
{ pkgs ? import {} }:
pkgs.mkShell {
buildInputs = [ pkgs.go ];
} 然后在这个目录下运行nix-shell,就会自动加载最新版Go。如果你想指定版本,可以写成pkgs.go_1_20。
这种方式的好处是灵活:你可以为不同项目配置不同的Go版本,互不干扰。
- 想用特定版本?改一下
buildInputs - 想加工具链?比如
goreman或golangci-lint,也只需加进去就行
配合Flakes使用(进阶)
如果你用上了Nix Flakes,可以在flake.nix里定义开发环境:
{
description = "Go dev environment";
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
outputs = { self, nixpkgs }: let
system = "x86_64-linux";
pkgs = import nixpkgs { inherit system; };
in {
devShells.default = pkgs.mkShell {
buildInputs = [ pkgs.go_1_20 ];
};
};
}然后在项目根目录运行nix develop就能进入预设好的Go环境了。
Flakes的优势在于可组合性强,方便你在多个项目之间共享或继承配置。
GOPROXY和模块代理设置(细节提示)
Go模块在国内访问可能会慢,建议在配置中加上国内代理:
export GOPROXY=https://goproxy.cn,direct
你可以把这个写入到你的shell初始化脚本中,或者直接放在mkShell的shellHook里:
shellHook = '' export GOPROXY=https://goproxy.cn,direct '';
这样无论在哪台机器上重建环境,都能保证模块下载速度。
基本上就这些。用好Nix的声明式方式,Go环境管理其实挺顺手的。










