概要
自分用メモ。コマンドの羅列だけ。
目次
(1) 各種アップデート
1-1. wsl
1-2. openSuSE
1-3. pyenv
1-4. pipx
1-5. poetry
1-6. vscode
1-7. powershell
(2) wsl2ディストリビューション
2-1. export
2-2. import
2-3. host名/デフォルトログインユーザの変更
2-4. 割り当て量の変更
2-5. bashのPS1変更
(1) 各種アップデート
1-1. wsl
windowsのpowershellから実施
# バージョン確認
wsl --version
# アップデート
wsl --update
# バージョン確認
wsl --version
1-2. openSuSE
linuxのターミナルから実施
# レポジトリ更新
sudo zypper refresh
# アップデート
sudo zypper dup
windowsのpowershellから実施
wsl2からアクセスしているエントリを削除する。
稼働環境は消えるが、ベースとなるopenSuSEはアプリとして導入されたままとなる。
wsl -l -v
wsl --unregister openSUSE-Leap-15.6
wsl -l -v
windowsからwslディストリビューション削除
openSuSEをアプリとして削除する。
# 削除前確認
winget list --id SUSE.openSUSE.Leap.15.6
# 削除
winget uninstall PowerShell
# 削除後
winget list --id SUSE.openSUSE.Leap.15.6
1-3. pyenv
linuxのターミナルから実施
# バージョン確認
pyenv --version
# pyenv導入ディレクトリ確認
ehco $(pyenv root)
# clone
git clone https://github.com/pyenv/pyenv-update.git $(pyenv root)/plugins/pyenv-update ; echo $?
# アップデート
pyenv update
# バージョン確認
pyenv --version
# pyenv用フォルダ削除
# 削除前に$(pyenv root)の中身が入っていることを確認
ehco $(pyenv root)
# pyenv用フォルダ削除
rm -rf $(pyenv root) ; echo $?
# bash自動補完設定削除
ls -l /etc/bash_completion.d/pyenv.bash
sudo -rf /etc/bash_completion.d/pyenv.bash ; echo $?
ls -l /etc/bash_completion.d/pyenv.bash
# ~/.bashrc中の下記の記載を削除またはコメントアウト
# env for pyenv
export PYENV_ROOT="$HOME/.pyenv"
[[ -d $PYENV_ROOT/bin ]] && export PATH="$PYENV_ROOT/bin:$PATH"
eval "$(pyenv init -)"
1-4. pipx
# バージョン確認
pipx --version
# pipxそのものでpipxをアップデートするのは危険なため
# toolとして導入しておいたをpipx.pyz使用する。
# pipx.pyzを蹴るpythonは新しめで使える奴なら何でもいい。
python3.11 ~/tool/pipx.pyz upgrade pipx ; echo $?
# バージョン確認
pipx --version
# toolとして導入しておいたをpipx.pyz使用する。
python3.11 ~/tool/pipx.pyz uninstall pipx ; echo $?
# ~/.bashrc中の下記の記載を削除またはコメントアウト
# env for pipx
eval "$(register-python-argcomplete pipx)"
1-5. poetry
# Python仮想環境ディレクトリへ移動
cd ~/work/vmPy/vqis
pwd
# モジュールアップデート
poetry update ; echo $?
# バージョン確認
poetry about
# poetryのアップデート
pipx upgrade poetry ; echo $?
# バージョン確認
poetry about
# "pyproject.toml"を受け渡し、Python仮想環境に配置したうえで
# 下記コマンドを実行。
# この方法の場合、ある程度は実行環境に合わせたパッケージ選択が行われるが、
# 実行環境やタイミングにより、完全に同じパッケージとなる保証はない。
poetry install --no-root ; echo $?
1-7. powershell
アップデート
windowsのpowershellから実施
# バージョン確認
$PSVersionTable
# 最新版確認
winget search Microsoft.PowerShell
#------最新版が出てれば更新
# 削除
winget uninstall PowerShell
# 導入
winget install --id Microsoft.Powershell --source winget
# バージョン確認
$PSVersionTable
# [参考] upgradeコマンド
winget upgrade PowerShell
(2) wsl2ディストリビューション
2-1. export
wsl2でexportを行うとlinux仮想環境を丸ごとバックアップできます。
★export前にlinuxからログオフ、vscodeも終了させてください。
wsl -l -v
wsl --shutdown
wsl -l -v
# windows側にバックアップ先ディレクトリ作成
# 保管用フォルダ作成(フォルダ名等は適当)
$dirTGTe = "C:\wsl2\bkup\"
$dirTGTe
Test-Path "$dirTGTe"
New-Item -ItemType Directory -Path "$dirTGTe"
Test-Path "$dirTGTe"
# export対象は "wsl -l -v" コマンド出力のNAMEを指定する。
wsl --export openSUSE-Leap-15.6 $dirTGTe\openSUSE-Leap.vhdx --vhd
2-2. import
exportした仮想環境のイメージをimportします。
import時に下記を変更できるためwsl2のディストリビューション導入後、
最初に実施するのがおすすめです。
・仮想環境名(ディストリビューション名)。名前を短縮できるのがメリット大。
・ファイルシステムの配置ディレクトリを管理しやすい場所に設定できる。
★import後のlinuxはなぜかrootでログインするようになるので、
後述のデフォルトログインユーザの変更を実施すること。
# windows側にバックアップ先ディレクトリ作成
# 保管用フォルダ作成(フォルダ名等は適当)
$dirTGTi = "C:\wsl2\img\suseLeap"
$dirTGTi
Test-Path "$dirTGTi"
New-Item -ItemType Directory -Path "$dirTGTi"
Test-Path "$dirTGTi"
# --importの引数が新仮想環境名
wsl --import suseLeap $dirTGTi $dirTGTe\openSUSE-Leap.vhdx --vhd
# import確認。新仮想環境名のlinuxが増える
wsl -l -v
importした新環境へのアクセス
(a) import操作によって自動的にwindowsターミナルのプロパティが作成されているため、
windowsターミナルアプリのタイトルバーから新環境を選ぶとログオンできる。
(b) スタートメニューにあるwindowsターミナルアイコンのコピー方法がわからなかった。
ショートカットアイコンやブログラムとしてのファイルの実体が見当たらない。
もしエントリが見つかれば、コピー&改造して新環境ログインに使用できるはず。
(c) 自分はwindowsターミナルではなく、wslttyを使用している。
wslttyではインストーラーが自動的にスタートメニューへの登録してくれるほか、
作成されたショートカットをコピーして、パラメータを変更するだけで他環境へログオンができるので管理がかなり楽。
cygwinで使用されているminttyに慣れているのならベスト。
★wslttyのインストーラをダウンロードすると、windowsの警告「一般的にはダウンロードされていません」
が出力されるので、ここでは説明しません。
2-3. host名/デフォルトログインユーザの変更
★/etc/wsl.conf.wsl_baseの変更/反映前にexportを取得すること。
パラメータの設定によっては2度と起動しなくなることがあるので注意。
★openSuSEでは/etc/wsl.confから/etc/wsl.conf.wsl_baseへのソフトリンクが張られている。
他のディストリビューションでは多分etc/wsl.conf。
# バックアップ
ls -l /etc/wsl.conf.wsl_base
sudo cp -p /etc/wsl.conf.wsl_base /etc/wsl.conf.wsl_base_orig ; echo $?
# 編集
sudo vi /etc/wsl.conf.wsl_base
# 確認
diff /etc/wsl.conf.wsl_base /etc/wsl.conf.wsl_base_orig ; echo $?
cat /etc/wsl.conf.wsl_base
/etc/wsl.conf.wsl_baseを下記の通り編集
[boot]のsystemdでsystemd有効化。
wsl_systemd導入前に設定してしまうと二度と起動しなくなる。
[network]のhostnameでホスト名を指定
[user]のdefaultでデフォルトのログインユーザを指定
[wsl2]のdnsTunnelingでdnsはwindowsからもらってくる
編集後、再起動して反映
# added by wsl_base pattern
[boot]
command=/usr/sbin/sysctl -w net.ipv4.ping_group_range=\"0 2147483647\"
# END: wsl_base pattern edit
[boot]
systemd = true
[network]
hostname = suseLeap
[user]
default = nyanco
[wsl2]
dnsTunneling = true
2-4. メモリ割り当て量変更
WSL2ではPC全体のメモリの半分、または8GBのいずれか少ない方が設定される。
この量を手動で設定したい場合には、デフォルトユーザのホームディレクトリに
".wslconfig"ファイルを作成して設定する。
# メモリ割り当て量確認
free --giga
# 既存のファイル確認
ls -l ~/.wslconfig
# 存在しない場合は作る。
touch ~/.wslconfig
vi ~/.wslconfig
cat ~/.wslconfig
# 再起動後
# メモリ割り当て量確認
free --giga
12GB固定で設定する場合
[wsl2]
memory=12GB
swap=0GB
2-5. bashのPS1変更
bashのPS1変数を変更してコマンドプロンプトを自分の好きな感じにする。
~..bashrcのに記載しておく
echo 'export PS1="\[\e[0;36m\]\[$(ppwd)\][\u@\h]:\w\n> \[\e[0m\]"' >> ~/.bashrc
source ~/.bashrc
Qiskit環境構築
【uv版】
(1) Linuxの導入/設定
(2) uvの導入/Python仮想環境の作成
【poetry版】
(1) Linuxの導入/設定
(2) Python仮想環境の作成
【uv/poetry共通】
(3) vscodeからのPython仮想環境接続
(4) シミュレータでの量子回路実行
(5) IBMQ実機での量子回路実行
(6) メンテナンス