2020-06-03 12:07:42 -04:00
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE - RUN doctoc TO UPDATE -->
2021-08-22 13:50:49 -05:00
# npm Install Requirements
2020-05-12 23:11:31 -04:00
2021-07-07 11:00:51 -05:00
- [Node.js version ](#nodejs-version )
2021-03-09 14:47:23 -07:00
- [Ubuntu, Debian ](#ubuntu-debian )
- [Fedora, CentOS, RHEL ](#fedora-centos-rhel )
- [Alpine ](#alpine )
- [macOS ](#macos )
- [FreeBSD ](#freebsd )
2021-08-22 13:50:49 -05:00
- [Windows ](#windows )
- [Installing ](#installing )
- [Troubleshooting ](#troubleshooting )
- [Issues with Node.js after version upgrades ](#issues-with-nodejs-after-version-upgrades )
2021-08-24 15:25:04 -07:00
- [Debugging install issues with npm ](#debugging-install-issues-with-npm )
2020-06-03 12:07:42 -04:00
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
2021-07-07 11:00:51 -05:00
If you're installing code-server via `npm` , you'll need to install additional
dependencies required to build the native modules used by VS Code. This article
includes installing instructions based on your operating system.
2020-05-12 23:11:31 -04:00
2022-08-30 10:00:11 -07:00
> **WARNING**: Do not use `yarn` to install code-server. Unlike `npm`, it does not respect
> lockfiles for distributed applications. It will instead use the latest version
> available at installation time - which might not be the one used for a given
> code-server release, and [might lead to unexpected behavior](https://github.com/coder/code-server/issues/4927).
2021-07-07 11:00:51 -05:00
## Node.js version
2021-03-09 11:20:14 -07:00
2022-05-04 14:58:49 -07:00
We use the same major version of Node.js shipped with Code's remote, which is
currently `16.x` . VS Code also [lists Node.js
2021-07-07 11:00:51 -05:00
requirements](https://github.com/microsoft/vscode/wiki/How-to-Contribute#prerequisites ).
2021-03-09 11:20:14 -07:00
2021-07-07 11:00:51 -05:00
Using other versions of Node.js [may lead to unexpected
2022-02-01 22:15:19 +05:30
behavior](https://github.com/coder/code-server/issues/1633).
2020-05-14 21:37:58 -04:00
2020-05-12 23:11:31 -04:00
## Ubuntu, Debian
```bash
sudo apt-get install -y \
build-essential \
pkg-config \
2020-08-26 13:54:42 -04:00
python3
npm config set python python3
2020-05-12 23:11:31 -04:00
```
2021-08-22 12:36:41 -05:00
Proceed to [installing ](#installing )
2020-05-20 12:13:03 -04:00
## Fedora, CentOS, RHEL
2020-05-12 23:11:31 -04:00
```bash
sudo yum groupinstall -y 'Development Tools'
2020-06-03 11:41:13 -04:00
sudo yum config-manager --set-enabled PowerTools # unnecessary on CentOS 7
2021-03-25 22:20:58 +05:30
sudo yum install -y python2
2020-05-12 23:11:31 -04:00
npm config set python python2
```
2021-08-22 12:36:41 -05:00
Proceed to [installing ](#installing )
2020-12-18 18:08:36 +00:00
## Alpine
```bash
2021-03-25 22:20:58 +05:30
apk add alpine-sdk bash libstdc++ libc6-compat
2020-12-18 18:08:36 +00:00
npm config set python python3
```
2021-08-22 12:36:41 -05:00
Proceed to [installing ](#installing )
2020-05-12 23:11:31 -04:00
## macOS
2020-12-04 02:34:18 -05:00
2020-05-12 23:11:31 -04:00
```bash
xcode-select --install
```
2020-12-14 18:25:08 -05:00
2021-08-22 12:36:41 -05:00
Proceed to [installing ](#installing )
2020-12-14 18:25:08 -05:00
## FreeBSD
```sh
2022-08-30 10:00:11 -07:00
pkg install -y git python npm-node16 pkgconf
2021-03-25 22:20:58 +05:30
pkg install -y libinotify
2020-12-14 18:25:08 -05:00
```
2021-07-07 11:00:51 -05:00
2021-08-22 12:36:41 -05:00
Proceed to [installing ](#installing )
## Windows
Installing code-server requires all of the [prerequisites for VS Code development ](https://github.com/Microsoft/vscode/wiki/How-to-Contribute#prerequisites ). When installing the C++ compiler tool chain, we recommend using "Option 2: Visual Studio 2019" for best results.
Next, install code-server with:
```bash
2022-08-30 10:00:11 -07:00
npm install --global code-server --unsafe-perm
2021-08-22 12:36:41 -05:00
code-server
# Now visit http://127.0.0.1:8080. Your password is in ~/.config/code-server/config.yaml
```
2021-08-23 11:06:34 -05:00
A `postinstall.sh` script will attempt to run. Select your terminal (e.g., Git bash) as the default application for `.sh` files. If an additional dialog does not appear, run the install command again.
2021-08-22 12:36:41 -05:00
2021-08-22 12:45:09 -05:00
If the `code-server` command is not found, you'll need to [add a directory to your PATH ](https://www.architectryan.com/2018/03/17/add-to-the-path-on-windows-10/ ). To find the directory, use the following command:
2021-08-22 12:36:41 -05:00
```shell
2022-08-30 10:00:11 -07:00
npm config get prefix
2021-08-22 12:36:41 -05:00
```
2022-02-01 22:15:19 +05:30
For help and additional troubleshooting, see [#1397 ](https://github.com/coder/code-server/issues/1397 ).
2021-08-22 12:36:41 -05:00
## Installing
2021-08-23 11:06:44 -05:00
After adding the dependencies for your OS, install the code-server package globally:
2021-08-22 12:36:41 -05:00
```bash
2022-08-30 10:00:11 -07:00
npm install --global code-server --unsafe-perm
2021-08-22 12:36:41 -05:00
code-server
# Now visit http://127.0.0.1:8080. Your password is in ~/.config/code-server/config.yaml
```
## Troubleshooting
If you need further assistance, post on our [GitHub Discussions
2022-02-01 22:15:19 +05:30
page](https://github.com/coder/code-server/discussions).
2021-08-22 12:36:41 -05:00
### Issues with Node.js after version upgrades
2021-07-07 11:00:51 -05:00
Occasionally, you may run into issues with Node.js.
2022-08-30 10:00:11 -07:00
If you install code-server using `npm` , and you upgrade your Node.js
2021-07-07 11:00:51 -05:00
version, you may need to reinstall code-server to recompile native modules.
Sometimes, you can get around this by navigating into code-server's `lib/vscode`
directory and running `npm rebuild` to recompile the modules.
A step-by-step example of how you might do this is:
1. Install code-server: `brew install code-server`
2. Navigate into the directory: `cd /usr/local/Cellar/code-server/<version>/libexec/lib/vscode/`
3. Recompile the native modules: `npm rebuild`
4. Restart code-server
2021-08-24 15:25:04 -07:00
### Debugging install issues with npm
2022-08-30 10:00:11 -07:00
To debug installation issues, install with `npm` :
2021-08-24 15:25:04 -07:00
```shell
# Uninstall
2022-08-30 10:00:11 -07:00
npm uninstall --global --unsafe-perm code-server > /dev/null 2>& 1
2021-08-24 15:25:04 -07:00
# Install with logging
2022-08-30 10:00:11 -07:00
npm install --loglevel verbose --global --unsafe-perm code-server
2021-08-24 15:25:04 -07:00
```