Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

proposal: cmd/go: GOTOOLCHAIN=mod to use exact version of toolchain directive #69956

Open
moznion opened this issue Oct 21, 2024 · 5 comments
Open
Labels
Milestone

Comments

@moznion
Copy link

moznion commented Oct 21, 2024

Proposal Details

Currently, the local Go runtime determines the actual Go version to use by checking the toolchain directive in the go.mod file when GOTOOLCHAIN=auto is set. If the local Go runtime is newer than the version specified in the toolchain directive, it defaults to the local Go version. This behavior aligns with the Go Toolchain documentation.

However, in some cases—such as in production environments—it may be necessary to enforce a specific Go runtime version, even though Go maintains strong forward and backward compatibility. For example, if the toolchain directive specifies 1.22.8 but the Go runtime in the container is 1.23.2, the actual version used would be 1.23.2. This could lead to unexpected issues if the container runtime is updated (even toolchain is never changed), which should sometimes be blocked to prevent unexpected factors.

While setting GOTOOLCHAIN=<version> is a valid solution but usually this GOTOOLCHAIN environment variables might be in disorder in a project; this is against the DRY principle. I believe it would be more convenient to have an option that always respects the version specified in the toolchain directive as the actual runtime version. This would allow developers to control the Go version for an application simply by modifying the version in the toolchain directive.

As a potential solution, how about introducing an option like GOTOOLCHAIN=mod to achieve this behavior?

@gopherbot gopherbot added this to the Proposal milestone Oct 21, 2024
@zigo101

This comment was marked as off-topic.

@seankhliao
Copy link
Member

If you can enforce GOTOOLCHAIN=mod, then you can also enforce GOTOOLCHAIN=target-version.

That said, from experience, if you need to enforce versions, it's better to do that at the time of providing the toolchain into the build environment, including in providing the container. This avoids any possibility of environment misconfiguration and inefficiencies resulting from needing to download and perform a toolchain switch.

@seankhliao seankhliao changed the title proposal: cmd/go: Add support for the GOTOOLCHAIN option to respect the runtime version specified in the toolchain directive of the go.mod file proposal: cmd/go: GOTOOLCHAIN=mod to use exact version of toolchain directive Oct 21, 2024
@zigo101
Copy link

zigo101 commented Oct 21, 2024

GOTOOLCHAIN=target-version is for all Go projects built on the machine. OP needs a project specific way.

@ianlancetaylor ianlancetaylor moved this to Incoming in Proposals Oct 21, 2024
@rsc
Copy link
Contributor

rsc commented Nov 20, 2024

In general we don't want to make it too easy for people to downgrade their go versions.
GOTOOLCHAIN=mod is a forced downgrade eventually, and that's bad.
Avoiding downgrades is the same reason we have minimal version selection.
You can think of GOTOOLCHAIN as being minimal version selection for Go toolchains.

GOTOOLCHAIN=go1.23.4 is like 'go get [email protected]' and selects an exact version.
But any non-explicit setting should be some kind of max (minimum value satisfying the input requirements)
that includes the fact that you installed 1.23.6 as a signal that you want to use 1.23.6 or newer.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: Incoming
Development

No branches or pull requests

6 participants