The main goal of this project is to provide a single command wslctl
to create, backup and manage
WSL (Windows Subsystem for Linux) instances on a windows 10 host.
It can deal with WSL1 and WSL2 instances (only if system is configured).
There no exe building, only powershell scripts (OOP). Thus, everything is reviewable and auditable.
- manage (set/get) default wsl version
- halt wsl windows service (shutdown all instances)
- create/remove/list wsl instances (extended infos)
- default user creation on new instance with sudo capabilities (username/pwd configurable)
- start/stop/status wsl instance (backgroud)
- instance version convertion (v1 <-> v2)
- manage default distribution
- remote execute commands/script
- bash to wsl instance
- build distribution from Dockerfile
- custom configuration file
- rename instance
- clone instance
Registry Management
- configurable endpoint (local or remote public url(read))
- local cache of distributions (pull)
- list/search of available distributions
- distributions informations (size, date, description)
- download integrity (sha256)
- local cache cleanup
- multi repository management
- accept .tar.xz files (@see https://github.com/Biswa96/WSLInstall/blob/master/docs/Make_RootFS.md)
- main repository linked with (@see https://uk.lxd.images.canonical.com/images/)
Backup Management
- local backups informations (sha256, size, date, description, wsl name)
- list/search of available local backups
- remove backup by name
- restore backup by name
- restore confirmation when wsl instance already exists
- restore with another name
This tool manage the wsl processus and wsl distribution instances.
wsl.exe
need to be installed first.
You can use the ./files/wsl-setup.ps1
script (need admin privileges) to setup everithings.
There are many options :
- clone this repository (updatable via git tags)
- download a specific version from gitlab releases and extract to a directory of your choice (manualy updatable)
- prefered: install via scoop.sh (non admin) with my buckets (mbl-35/scoop-srsrns)
Remember to add the resulting directory to your windows
%PATH%
for a non scoop installation
The tool has no default configuration set. We need first to add repositories to the registry. You should at least change that value with the following command:
PS> wslctl registry add <name> <registry-base-endpoint>
Example
PS> wslctl registry add yours https://your.repository.target
The custom configuration file is a json file named wslctl.json
located next to the cmd file.
Supported configuration parameters :
Name | Description | Default Value |
---|---|---|
wsl | wsl binary location | "c:\windows\system32\wsl.exe" |
appData | where to store everythings | "{$env:LOCALAPPDATA} \Wslctl" |
Get the registry URL and type folloging commands:
# get metadata from registry:
PS> wslctl registry add main https://raw.githubusercontent.com/mbl-35/wslctl-main/main
PS> wslctl registry update
# optionnal
PS> wslctl version default 2
# create wsl instance
PS> wslctl create ubuntu:20.04
You will have a fresh ubuntu focal named
ubuntu-20.04
install with your windows user name as default user
More commands to demonstrate the backup / restore functionalities :
# connect to the previously created instance
PS> wslctl exec ubuntu-20.04
# Do Stuff
$ echo "toto"
toto
...
$ exit
# backup your instance
PS> wslctl backup ubuntu-20.04 "Saving my stuff"
backup name is ubuntu-20.04-bkp.00
# connect to the instance
PS> wslctl exec ubuntu-20.04
# Do something stupid ...
$ sudo rm -rf /etc
...
$ exit
# Restore the instance (removing actual broken instance)
PS> wslctl backup restore ubuntu-20.04-bkp.00 --force
wslctl
coul be used from windows shell prompt (powershell or cmd), but also from a wsl instance
(if the bash $PATH
environment variable contains the wslctl
directory).
Use the --help
option to get the tool usage :
PS> wslctl --help
wslctl COMMAND [ARG...]
wslctl [ --help | --version ]
create <distro_name> [<wsl_name>] [--pwd=<pwd>] Create a named wsl instance from distribution
convert <wsl_name> <version> Concert instance to specified wsl version
rm <wsl_name> Remove a wsl instance by name
exec <wsl_name> [|<file.sh>|<cmd>] Execute specified script|cmd on wsl instance by names
ls List all created wsl instance names
start <wsl_name> Start an instance by name
stop <wsl_name> Stop an instance by name
status [<wsl_name>] List all or specified wsl Instance status
halt Shutdown all wsl instances
version [|<wsl_name>|default [|<version>]] Set/get default version or get wsl instances version
registry add <name> <remote_url> Add a registry repository to list
registry rm <name> Remove the registry repository from the list
registry update Update distribution dictionary from registry repositories
registry pull <distro> Pull remote distribution to local registry
registry purge Remove all local registry content
registry search <distro_pattern> Extract defined distributions from local registry
registry ls List local registry distributions
backup create <wsl_name> <description> Create a new backup for the specified wsl instance
backup rm <backup_name> Remove a backup by name
backup restore <backup_name> [--force] Restore a wsl instance from backup
backup search <backup_pattern> Find a created backup with input as pattern
backup ls List all created backups
backup purge Remove all created backups
Note: Because of
powershell
remove quotes from command line, we have to pay attention to the escape character sequence in arguments. Here is an example :PS> ./src/wslctl.ps1 backup create ubuntu-20.04 "focal backup" ok PS> powershell ./src/wslctl.ps1 backup create ubuntu-20.04 "focal backup" ok PS> powershell ./src/wslctl.ps1 backup create ubuntu-20.04 "'focal backup'" Error: too few arguments
# create wsl instance named 'my-ubuntu' with release 'ubuntu-18.04'
# default wsl version
PS1> .\src\wslctl.cmd create --pwd=Chang3M3 my-ubuntu ubuntu-18.04
* Import my-ubuntu
Check import requirements ...
Download distribution 'ubuntu-18.04' ...
Create wsl instance 'my-ubuntu' (wsl-version: 2)...
Adding group `me` (GID 1000) ...
Done.
* my-ubuntu created
Could be started with command: wslctl start my-ubuntu
# remove it
PS1> .\src\wslctl.cmd rm my-ubuntu
* my-ubuntu removed
# same creation with specific wsl version
PS1> .\src\wslctl.cmd create my-ubuntu ubuntu-18.04 --v1
* Import my-ubuntu
Check import requirements ...
Download distribution 'ubuntu-18.04' ...
Create wsl instance 'my-ubuntu' (wsl-version: 1)...
Adding group `me` (GID 1000) ...
Done.
* my-ubuntu created
Could be started with command: wslctl start my-ubuntu
# connect to it
> .\src\wslctl.cmd exec my-ubuntu
Connect to my-ubuntu ...
To run a command as administrator (user "root"), use "sudo <command>".
See "man sudo_root" for details.
me@host:/mnt/c/Users/me/home/github/wslctl$
# Call remote command
PS1> .\src\wslctl.cmd exec ubuntu-14.04.5 echo "toto tata"
Execute command 'echo toto tata' on ubuntu-14.04.5 ...
toto tata
PS1> .\src\wslctl.cmd exec ubuntu-18.04 "echo tata; echo toto"
Execute command 'echo tata; echo toto' on ubuntu-18.04 ...
tata
toto
PS1> .\src\wslctl.cmd exec ubuntu-18.04 "ls -lrt /tmp"
Execute command 'ls -lrt /tmp' on ubuntu-18.04 ...
total 141920
drwx------ 1 root root 4096 Jul 31 2020 tmp5lkby6kk
drwx------ 1 root root 4096 Sep 24 2020 pulse-CcctT9RwKSB1
drwx------ 1 root root 4096 Dec 10 2020 tmp6g20k01_
...
PS1> .\src\wslctl.cmd exec ubuntu-18.04 ls -lrt /tmp
Execute command 'ls -lrt /tmp' on ubuntu-18.04 ...
total 141920
drwx------ 1 root root 4096 Jul 31 2020 tmp5lkby6kk
drwx------ 1 root root 4096 Sep 24 2020 pulse-CcctT9RwKSB1
drwx------ 1 root root 4096 Dec 10 2020 tmp6g20k01_
...
# Call local script with args
PS1> .\src\wslctl.cmd exec ubuntu-18.04 .\tests\test-called-script.sh arg1 arg2
Execute test.sh on ubuntu-18.04 ...
SCRIPT_WINPATH=/mnt/c/Users/me/home/github/wslctl/tests/test-called-script.sh
hello from script file !
arg: arg1
arg: arg2
# Connect to wsl
PS1> .\src\wslctl.cmd exec ubuntu-18.04
Connect to ubuntu-18.04 ...
me@host:/mnt/c/Users/me/home/github/wslctl$
The registry is a list of remote or local repository to store retrivable distributions archives, and distributions metadatas. There is no public registry repository (right now), because of probably sensitive informations stored in customized entity (or business) resulting distributions.
The registry endpoint
represents the registry base Url (ability to be in the local filesystem). Under that endpoint,
we have the metadata file definition (named register.json
), and all the downloadable distributions files.
wslctl
manage a local cache of all downloaded file from registry endpoints (stored in the Registry
subdirectory
of the user configuration parameter appData
).
Content of the register.json
file: a hashtable of named distribution associated with its properties.
Distributions properties :
Field | Description | Example |
---|---|---|
date | Date of distribution production | 2021/09/04 14:09:00 |
desciption | Distribution description | Official Archived Version", |
archive | Name of the distribution archive in the registry endpoint | ubuntu-14.04.5-server-cloudimg-amd64-wsl.rootfs.tar.gz |
sha256 | Archive integrity checksum (sha256) | 93ac63df1badf4642e0d6074ca3d31866b8fc2a7ed386460db0b915eaf447b94 |
size | Archive size (human readable format) | 230,10 MB |
Lets see a private repository endpoints <domain>/canonical
and <domain>/extras
-
Remote Filesystem Structure
. ├── canonical │ ├── ms-ubuntu │ │ ├── 14.04 │ │ │ ├── ms-ubuntu-14.04.5.3-server-cloudimg-amd64-wsl-rootfs.tar.gz │ │ │ └── ms-ubuntu-14.04.6-server-cloudimg-amd64-wsl-rootfs.tar.gz │ │ ├── 16.04 │ │ │ └── release-2019.523 │ │ │ └── ms-ubuntu-16.04.2-server-cloudimg-amd64-wsl-rootfs.tar.gz │ │ ├── 18.04 │ │ │ └── ms-ubuntu-18.04.2-server-cloudimg-amd64-wsl-rootfs.tar.gz │ │ └── 20.04 │ │ └── ms-ubuntu-20.04-server-cloudimg-amd64-wsl-rootfs.tar.gz │ ├── register.json │ └── ubuntu │ ├── 16.04 │ │ ├── release-20210429 │ │ │ └── ubuntu-16.04-server-cloudimg-amd64-wsl.rootfs.tar.gz │ │ └── release-20211001 │ │ └── ubuntu-16.04-server-cloudimg-amd64-wsl.rootfs.tar.gz │ ├── 18.04 │ │ └── release-20211122 │ │ └── ubuntu-18.04-server-cloudimg-amd64-wsl.rootfs.tar.gz │ ├── 20.04 │ │ └── release-20211118 │ │ └── ubuntu-20.04-server-cloudimg-amd64-wsl.rootfs.tar.gz │ └── url.txt └─ extras ├── register.json └── wsl-vpnkit └── 0.2.4 └── wsl-vpnkit-0.2.4.tar.gz
-
The corresponding
~/extras/register.json
file{ "extras/wsl-vpnkit:0.2.4": { "source": "https://github.com/sakai135/wsl-vpnkit/releases/download/v0.2.4/wsl-vpnkit.tar.gz", "date": "2021/11/29 13:35:00", "description": "Official VPN-Kit Cisco Bridge (sakai135)", "note": "See: https://github.com/sakai135/wsl-vpnkit", "archive": "wsl-vpnkit/0.2.4/wsl-vpnkit-0.2.4.tar.gz", "sha256": "d4fbf1e7ae57b28a046b0515adbdab06914cd7a80d1ecd0b4a0b06c2b14743ad", "size": "11.50 MB" } }
-
The corresponding
~/canonical/register.json
file{ "ms-ubuntu:14.04.5": { "source": "https://wsldownload.azureedge.net/14.04.5.3-server-cloudimg-amd64-root.tar.gz", "date": "2021/06/11 07:53:00", "description": "Official Microsoft Archived Ubuntu Server 14.04 LTS (Trusty Tahr) release", "note": "Issues with initctl, policy-rc.d and tail", "archive": "ms-ubuntu/14.04/ms-ubuntu-14.04.5.3-server-cloudimg-amd64-wsl-rootfs.tar.gz", "sha256": "ff38b4c393260d1a282c0987005de5d2704d94979f247c90d548e85badcff673", "size": "181.80 MB" }, "ms-ubuntu:14.04.6": { "source": "Updated from ms-ubuntu:14.04.5", "date": "2021/09/04 14:09:00", "description": "Official Microsoft Archived Ubuntu Server 14.04 LTS (Trusty Tahr) Patched release", "note": "Patched and updated", "archive": "ms-ubuntu/14.04/ms-ubuntu-14.04.6-server-cloudimg-amd64-wsl-rootfs.tar.gz", "sha256": "16daf3303bd416349daff2120b4a53ffedea18b490c217944f9f08777bafeca6", "size": "228.63 MB" }, "ms-ubuntu:16.04.2": { "source": "https://wsldownload.azureedge.net/16.04.2-server-cloudimg-amd64-root.tar.gz", "date": "2021/06/11 07:53:00", "description": "Official Microsoft Archived Ubuntu Server 16.04 (Xenial Xerus) release", "note": "", "archive": "ms-ubuntu/16.04/release-2019.523/ms-ubuntu-16.04.2-server-cloudimg-amd64-wsl-rootfs.tar.gz", "sha256": "247314273c421a9c9ab11951ca4543ca2297d2fb557887a9a8948d1295794a91", "size": "225.82 MB" }, "ms-ubuntu:18.04.2": { "source": "https://wsldownload.azureedge.net/Ubuntu_1804.2019.522.0_x64.appx", "date": "2019/05/22 12:00:00", "description": "Official Microsoft Ubuntu Server 18.04 (Bionic Beaver) release [2019.522]", "note": "Extracted from downloaded appx", "archive": "ms-ubuntu/18.04/ms-ubuntu-18.04.2-server-cloudimg-amd64-wsl-rootfs.tar.gz", "sha256": "7d220d798b75769d774358677b4cdb1ee556129f64005587dbe9ea8d50b38bd2", "size": "220.47 MB" }, "ms-ubuntu:20.04": { "source": "https://wsldownload.azureedge.net/Ubuntu_2004.2020.424.0_x64.appx", "date": "2020/04/23 12:00:00", "description": "Official Microsoft Ubuntu Server 20.04 LTS (Focal Fossa) release [2020.424]", "note": "Extracted from downloaded appx", "archive": "ms-ubuntu/20.04/ms-ubuntu-20.04-server-cloudimg-amd64-wsl-rootfs.tar.gz", "sha256": "9d286bf63f963fbcea20ce6ffb56e8e81be8cd47e50d4aaeae717c18abe78066", "size": "431.57 MB" }, "ubuntu:16.04.6": { "source": "https://cloud-images.ubuntu.com/releases/xenial/release-20210429/ubuntu-16.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "date": "2021/04/29 07:30:00", "description": "Official Ubuntu Server 16.04 LTS (Xenial Xerus) release [20210429]", "note": "", "archive": "ubuntu/16.04/release-20210429/ubuntu-16.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "sha256": "d26d46f5460cbd7bcdbd2a0676831bcd25773ef2f2fdf270aafd34bba2d0db00", "size": "243.69 MB" }, "ubuntu:16.04.7": { "source": "https://cloud-images.ubuntu.com/releases/xenial/release-20211001/ubuntu-16.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "date": "2021/10/02 07:30:00", "description": "Official Ubuntu Server 16.04 LTS (Xenial Xerus) release [20211001]", "note": "", "archive": "ubuntu/16.04/release-20211001/ubuntu-16.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "sha256": "746bad563c891240c505c4955c4a134749db3ff9d9b0fa15ec6cab77518260ff", "size": "244.92 MB" }, "ubuntu:18.04.6": { "source": "https://cloud-images.ubuntu.com/releases/bionic/release-20211122/ubuntu-18.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "date": "2021/11/23 07:00:00", "description": "Official Ubuntu Server 18.04 LTS (Bionic Beaver) release [20211122]", "note": "", "archive": "ubuntu/18.04/release-20211122/ubuntu-18.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "sha256": "d31c23cfbfbc1fae7f46d9d96db1c1c63666d739e28139b52766b3c22f2db6dc", "size": "278.78 MB" }, "ubuntu:20.04.3": { "source": "https://cloud-images.ubuntu.com/releases/focal/release-20211118/ubuntu-20.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "date": "2021/11/08 22:42:00", "description": "Official Ubuntu Server 20.04 LTS (Focal Fossa) release [20211118]", "note": "", "archive": "ubuntu/20.04/release-20211118/ubuntu-20.04-server-cloudimg-amd64-wsl.rootfs.tar.gz", "sha256": "6b88c529f44d4b0804ebf3ce5c4504df61dc0b114b9b3b82a01b44a7e4c5c6b1", "size": "469.47 MB" } }
-
Using that registry
# get metadata from registry: PS> wslctl registry add main https://<domain>/canonical PS> wslctl registry add extras https://<domain>/extras PS> wslctl registry update # list available distributions : PS> wslctl registry list Available distributions (installable): extras/wsl-vpnkit:0.2.4 [extras] 2021/11/29 13:35:00 11.50 MB Official VPN-Kit Cisco Bridge (sakai135) ms-ubuntu:14.04.5 [main] 2021/06/11 07:53:00 181.80 MB Official Microsoft Archived Ubuntu Server 14.04 LTS (Trusty Tahr) release ms-ubuntu:14.04.6 [main] 2021/09/04 14:09:00 228.63 MB Official Microsoft Archived Ubuntu Server 14.04 LTS (Trusty Tahr) Patched release ms-ubuntu:16.04.2 [main] 2021/06/11 07:53:00 225.82 MB Official Microsoft Archived Ubuntu Server 16.04 (Xenial Xerus) release ms-ubuntu:18.04.2 [main] 2019/05/22 12:00:00 220.47 MB Official Microsoft Ubuntu Server 18.04 (Bionic Beaver) release [2019.522] ms-ubuntu:20.04 [main] 2020/04/23 12:00:00 431.57 MB Official Microsoft Ubuntu Server 20.04 LTS (Focal Fossa) release [2020.424] ubuntu:16.04.6 [main] 2021/04/29 07:30:00 243.69 MB Official Ubuntu Server 16.04 LTS (Xenial Xerus) release [20210429] ubuntu:16.04.7 [main] 2021/10/02 07:30:00 244.92 MB Official Ubuntu Server 16.04 LTS (Xenial Xerus) release [20211001] ubuntu:18.04.6 [main] 2021/11/23 07:00:00 278.78 MB Official Ubuntu Server 18.04 LTS (Bionic Beaver) release [20211122] ubuntu:20.04.3 [main] 2021/11/08 22:42:00 469.47 MB Official Ubuntu Server 20.04 LTS (Focal Fossa) release [20211118] # create instance with available distribution PS> wslctl create ubuntu:20.04.3 PS> wslctl create extras/wsl-vpnkit:0.2.4
Once a wsl instance is created, we can save its state, and later restore it.
wslctl
manage a local backup directory (stored in the Backups
subdirectory of the user configuration parameter appData
).
That directory has a backup metadata file named backup.json
, storing all informations
(date, description, sha256, ...) of each realized backup, and all backup archives files in format
{wsl-name}-bkp-{backup-index}-amd64-wsl-rootfs.tar.gz
.
Lets see a local user backup directory %LOCALAPPDATA%\Wslctl\Backups
PS> dir C:\Users\me\AppData\Local\Wslctl\Backups
Mode LastWriteTime Length Name
---- ------------- ------ ----
-a---- 27/10/2021 17:25 1161 backups.json
-a---- 27/10/2021 09:06 241284793 ubuntu-14.04.5-bkp.00-amd64-wsl-rootfs.tar.gz
-a---- 27/10/2021 17:24 241284381 ubuntu-14.04.5-bkp.01-amd64-wsl-rootfs.tar.gz
Content of the backups.json
file: a hashtable of named distribution backuped, associated with its properties.
Distributions properties :
Field | Description | Example |
---|---|---|
date | Date of backup production | 2021/09/04 14:09:00 |
description | Backup description | Retest oop |
archive | Name of the distribution archive in the registry endpoint | ubuntu-14.04.5-bkp.01-amd64-wsl-rootfs.tar.gz |
sha256 | Archive integrity checksum (sha256) | df6ef87d8b449d039d49d94d9daa8b14ad34d23ce39f3d5e927b39d699a160ed |
size | Archive size (human readable format) | 230,10 MB |
wslname | Instance name from wich the backup has been realized | ubuntu-14.04.5 |
wslversion | Wsl version of the backuped instance | 2 |
The backup list
command is based on that file :
.\src\wslctl.cmd backup ls
Available Backups (recoverable):
ubuntu-14.04.5-bkp.00 - 2021/10/27 09:06:39 - 230,11 MB - test oop
ubuntu-14.04.5-bkp.01 - 2021/10/27 17:25:30 - 230,11 MB - Retest oop
Nothing pushed to registry nor backup.
Only the wsl instance is created.
# Create from Dockerfile set in directory (tag from dockerfile name)
> .\src\wslctl.cmd build .\tests\test.dockerfile
Building 'test' with .\tests\test.dockerfile
Parsing file ...
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'cmd' (ignored)
From : ubuntu:18.04
Tag : test
...
# Create from directory (tag from directory name)
# used Dockerfile default name
> .\src\wslctl.cmd build .\tests
Building 'tests' with .\tests\Dockerfile
Parsing file ...
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'cmd' (ignored)
From : ubuntu:18.04
Tag : tests
...
# Create wsl instance from specified Dockerfile and name it as specified tag name
> .\src\wslctl.cmd build .\tests\test.dockerfile --tag=ubuntu:18.04-mine --dry-run
DryRun - Building 'ubuntu:18.04-mine' with .\tests\test.dockerfile
Parsing file ...
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'cmd' (ignored)
From : ubuntu:18.04
Tag : ubuntu:18.04-mine
...
# Using the --dry-run option (nothing created, just verbose what to do)
> .\src\wslctl.cmd build .\tests\test.dockerfile --tag=ubuntu:18.04-mine --dry-run
DryRun - Building 'ubuntu:18.04-mine' with .\tests\test.dockerfile
Parsing file ...
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'expose' (ignored)
Warning: Unimplemented command 'cmd' (ignored)
From : ubuntu:18.04
Tag : ubuntu:18.04-mine
--------------Generated Script File --------------------
#!/usr/bin/env bash
# The script is generated from a Dockerfile via wslctl v1.0.5
# The Original DockerFile is from image : ubuntu:18.04
# Original DockerFile Maintainer: matsumotory
# -- Automatic change working directory:
cd /mnt/c/Users/me/home/github/wslctl/tests
# -- Converted commands:
apt-get -y update
apt-get -y install sudo openssh-server
apt-get -y install git
apt-get -y install curl
apt-get -y install rake
apt-get -y install ruby ruby-dev
apt-get -y install bison
apt-get -y install libcurl4-openssl-dev libssl-dev
apt-get -y install libhiredis-dev
apt-get -y install libmarkdown2-dev
apt-get -y install libcap-dev
apt-get -y install libcgroup-dev
apt-get -y install make
apt-get -y install libpcre3 libpcre3-dev
apt-get -y install libmysqlclient-dev
apt-get -y install gcc
cd /usr/local/src/ && git clone https://github.com/matsumotory/ngx_mruby.git
export NGINX_CONFIG_OPT_ENV="--with-http_stub_status_module --with-http_ssl_module --prefix=/usr/local/nginx --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module"
echo 'export NGINX_CONFIG_OPT_ENV="--with-http_stub_status_module --with-http_ssl_module --prefix=/usr/local/nginx --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module"'>> ~/.bashrc
cd /usr/local/src/ngx_mruby && sh build.sh && make install
--------------------------------------------------------
Usage of make.ps1
:
PS> ./make.ps1 test
# Correct with PSScriptAnalyser
PS> Get-Help Get-ScriptAnalyzerRule -ShowWindow
- Add changes to
./CHANGELOG.md
. - Change the version in
./src/wslctl.ps1
(just change themajor.minor.build
part for variable$version
). - Push to upstream:
git add . && git commit -m "commit message" && git push origin master
. - Run
$Version=(cmd /c powershell.exe .\src\wslctl.ps1 --version)
to retreive the binary version. - Create the tag with
git tag $Version
. - Push to upstream:
git push --tags origin master
.
PS> ./make.ps1