Ryzen 3700Xで一台組んだ

もともとRyzenに興味はあったので、いつかは組むつもりだったのだけど、勢いを得られないまま時間が過ぎていた。という訳で、増税前という小さな勢い付けをして、買ってきた。(10万くらいしか使ってないので、増税前後の差額は2000円くらいしかないのだが…) 構成は以下の通り。RAMは安かった時期に事前購入しておいたものを利用。
CPU:AMD Ryzen 3700X
RAM:CFD W4U2666CM-16G(16GBx2)
M/B:ASUS ROG STRIX B450-I GAMING
GPU:玄人志向 GF-GTX1650-E4GB/OC/DF
SSD:ADATA XPG SX8200 Pro(512GB)
PSU:KRPW-GK550W/90+
CAS:NZXT H210 以下、写真を貼っつけ。
いっしき(ケースうつってないけど)
今回の目玉(ケースが凄いでかい)
エンブレムつき
付属のクーラー。でかい。(デカさの伝わらない写真)
以前購入しておいたメモリ
ママン外観
ママンのオーディオ+M.2は思ったよりも高さがある
初めて買ったA-DATAのSSD。メーカーロゴの鳥さんが見当たらない
SSD中身。ヒートシンクっぽいのがついているが、今回は使わない
粘着テープと言えば3Mってとこある
てきとうに買ったクロシコのGTX 1650
ホコリ防止キャップは付属なし。
取り敢えずで組み込み。
恒例のメモリテスト
メモリテストは購入当時に回していなかったので今回す。今更初期不良があったところで交換対応はしてくれないと思うけど…。8パスくらいしてエラー無しだったのでokとして、早速ArchLinuxのインストールだ。 使用したのは2019年9月版のISO。起動後画面がついたり消えたりだったので(起動中にACPIエラーが出てるのが目についてたので)取り敢えずacpi=offをつけてやったら、無事起動したので良いとしよう。 その後はUEFI+GPTを前提にパーティショニング。パーティショニングはあまり拘らないので、gdiskでGPTなディスクにして、先頭(1番目)にef00な500MB程度のパーティション(つまりはESP)を作成、次(2番目)に全領域を使って/(root)を作成。
そしてフォーマットとマウント。

# mkfs.fat -F32 /dev/nvme0n1p1
# mkfs.ext4 /dev/nvme0n1p2
# mount /dev/nvme0n1p2 /mnt
# mkdir /mnt/boot
# mount /dev/nvme0n1p1 /mnt/boot

素直にインストールしていく。…が、いつも通りgrubを使おうと思ったらCould not prepare Boot variable: No such file or directoryとか言われてうまくいかなかったので(/sys/firmware/efi/efivarsはきちんとマウントしていたし、容量不足というわけでもなさそうだった…なんだったのだ)、systemd-bootを使ってみることにした。追加でインストールするべきパッケージも無いし良い。設定はsystemd-boot – ArchWikiを見れば良い。 あとは適当にGUI環境つくっていって好きに使えばいいね~~~(i3wm入れて動くようになっただけなので、実質的にはまだ作ってる最中だけど) 最近白っつー色が好きで、ケースどれにするかっていうので悩んだところ、NZXTのH210が良いじゃんということで決定。(録画鯖組んだときはIN WINの301だったが、その白もかっこよかった)
CPUにはRyzenのエンブレムステッカーがついてきたのだが、ケースに付けるか悩むところ。
それに、配線類が現状クソてきとうなので、システム構築が完了したなって思ったらきれいに配線し直そうと思うので、そのときにまたそれを追記するかな~

yayでPKGBUILDを編集する

aurヘルパーとしてyayを使っているのだけど、PKGBUILDを編集したいときに、デフォルトでは何も聞いてくれずに進んでいってしまう。かなしい。

$ yay --nodiffmenu --editmenu --editor vim --save

上記を実行すれば良い。引数はそれぞれ、
・PKGBUILDのdiff見る?をオフにする
・PKGBUILD編集する?をオンにする
・編集時のエディターをvimにする
・以上変更を保存する
を意味する。参考[https://github.com/Jguer/yay/blob/6cd47dd83c49689f0bd84c650feea9c71ed1aaf2/cmd.go] もともとはgnome-python-desktopのビルドが通らず、コメント見に行ったらconfigureの引数変えとけって書いてあったので、それがやりたかったのでした。置いてあるPKGBUILD編集してもyay実行するとcheckoutされてしまって…

dconfを使ってみる

EPSON DS-50000とかいうのを買ってみたのだけど(大変高価でした、ノリで購入するべきものではない)、Arch Linuxで使うにはimagescanを入れれば解決するとか。SANE/スキャナー別の問題 - ArchWiki で、こいつはutsushiとかいうフロントエンドを使えと要求するのだけど、微妙に使い勝手が悪い。ひとまず、保存先くらいは毎度初期値じゃなくて前回のものを使ってほしいなぁと思う。 utsushiはGPLv3っぽいので好きに改造して良いはずなので、いじってみた。いじったのはottyajp/utsushi – githubに置いたので、設定をいじる話だけこちらに書く。 schema定義をつくってコンパイルする。この後、dconf-editorでいじれるようになる。

$ cat /usr/share/glib-2.0/schemas/apps.utsushi.gschema.xml
<?xml version="1.0" encoding="UTF-8"?>
<schemalist gettext-domain="utsushi">

  <schema path="/apps/utsushi/" id="apps.utsushi">

    <key type="s" name="previous-path">
      <default>"~/"</default>
      <summary>previous path</summary>
      <description>previous path.
      </description>
    </key>

    <key type="i" name="resolution">
      <default>100</default>
      <summary>scan resolution</summary>
      <description>scan resolution.
      </description>
    </key>

  </schema>
</schemalist>
$ sudo glib-compile-schemas /usr/share/glib-2.0/schemas

C++から設定を読み込んだり書き込んだりする。

#include <gio/gio.h>

// load settings
GSettings *settings = g_settings_new("apps.utsushi");
GVariant *gvar = g_settings_get_value(settings, "previous-path");
gchar *path;
g_variant_get(gvar, "s", &amp;path);

// save settings
GSettings *settings = g_settings_new("apps.utsushi");
string str = "hoge";
GVariant *gvar = g_variant_new_string(str.c_str());
g_settings_set_value(settings, "previous-path", gvar);

本当はこれまで使っていたCanoScan LiDE 210みたいに、simple-scanでほいほい使えるとよかったんだけどなぁ。まぁ、DS-50000のスキャンはマジで早いしきれいだし、ハードウェアに文句は無いけどね。

Windows Terminalを使う

そういえば、とふと思い出してStoreを見てみたら入手できそうじゃないですか。取り敢えず入れてみましょう。
Preview版がインストールできそう
Preview版だけど入手できそう!
ところが、入手ボタンを押しても反応しない…なぜだ?と思ってよくよく見ていると、入手ボタンのちょい下の方に「システム要件を確認」つーのがある。これを押してみると…
システム必要条件
更新しないとダメくさい
最新のを入れましょう…更新ボタンから画面の指示に従っててきとうにアップデート。
Windowsを更新するぞ
さて、次はどの設定を崩してくれるのかな…
更新が完了するとインストールできるようになるので(なんだかんだ1時間くらいかかった気がする)ぶち込み。 背景がいじれるらしいのでやってみる。以下みたいなノリでprofiles.jsonの好きなprofileに書き加えて保存すると、即時適用される。

"backgroundImage": "C:\\temp\\bg.bmp",
"backgroundImageOpacity": 0.75,
"backgroundImageStrechMode": "fill",

背景画像を設定
文字色がアウツッ
てきとうにいじって、WSLなUbuntuで、文字が見えなくもないColor schemeに変えて、アイコンを変えたのが以下。
見えなくもないColor shemeとそれっぽいアイコン
背景画像指定を切って、useAcrylicをtrueにすれば、背景が透けてウィンドウの向こうが見えたりもする。
背景が透けて奥が見える
背景が透けて奥が見える
なんかいろいろ弄れそうなのだけど、設定について解説してるとこがあんま見当たらなくて(ジェネリックなネーミングなので検索がクソめんどい)面倒だったので、以上。

ArchLinuxでAndroidビルド

久々にAndroidビルドの需要が自分の中で高まった。何年も前にP-01D向けCyanogenmodのビルドにチャレンジした事はあるが、その時のソースコードは人の作ったものだったので、今回は自分でやってみたい。自分で試行錯誤したい。 大抵Ubuntu向け記事ばかりだが(そもそも公式の文書がUbuntu向け)急にUbuntuホストを用意するのも面倒。手元のArchLinuxでそのままやりたい。というわけで、一先ずソース修正の類は何もせず、Pixel用でビルドしてみる。 それっぽいパッケージ群のインストール。必要なもののみかどうかは自信無い。

$ yay -S base-devel
$ yay -S git gperf zip curl zlib lib32-glibc ccache mesa libxslt unzip jdk8-openjdk rsync
$ yay -S multilib-devel # lib32-ncurses5-compat-libsに必要
$ yay -S lib32-ncurses5-compat-libs # 実際必要かどうかは不明
$ yay -S ncurses5-compat-libs
$ yay -S python2

repoコマンドのインストール、pythonリンク作成、git初期設定。

$ mkdir ~/bin
$ PATH=~/bin:$PATH
$ curl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repo
$ chmod a+x ~/bin/repo
$ ln -s /usr/bin/python2 ~/bin/python
$ ln -s /usr/bin/python2-config ~/bin/python-config
$ git config --global user.email "hoge@fuga.com"
$ git config --global user.name "hoge"

Androidソースコードの入手。バージョンは8.0.0の最新にしてみる。

$ mkdir ~/git/aosp/android-8.0.0_r36
$ cd ~/git/aosp/android-8.0.0_r36
$ repo init -u https://android.googlesource.com/platform/manifest -b android-8.0.0_r36 # すぐ終わる
$ repo sync # めっちゃかかる

ビルド。

$ source build/envsetup.sh
$ lunch # 好きなデバイスを選択。今回はsailfish向けにしていた
$ make -j2

エラー出るので修正。pythonが無いよって言うけど、まさかパス決め打ちじゃないよね…?

/bin/bash: prebuilts/clang/host/linux-x86/clang-3859424/bin/clang++: /usr/bin/python: bad interpreter: No such file or directory
$ cd /usr/bin
$ sudo ln -s /usr/bin/python2 python
$ sudo ln -s /usr/bin/python2-config python-config

Jack serverと通信できないみたいなエラーが出るのでぐぐって対応。

Communiction error with Jack server (52). Try 'jack-diagnose'
$ ./prebuilts/sdk/tools/jack-admin stop-server
Stopping background server
No Jack server running. Try 'jack-admin start-server'
$ ./prebuilts/sdk/tools/jack-admin start-server

メモリがいっぱいになる件。

Out of memory error (version 1.3-rc6 'Douarn' (4418000 22a11d4b264ae70e366aed3025ef47362d1522bb
by android-jack-team@google.com)).
Java heap space.   
Try increasing heap size with java option '-Xmx<size>'.
$ ./prebuilts/sdk/tools/jack-admin stop-server
Stopping background server
$ ./prebuilts/sdk/tools/jack-admin cleanup-server
$ export JACK_SERVER_VM_ARGUMENTS="-Dfile.encoding=UTF-8 -XX:+TieredCompilation -Xmx4g"
$ ./prebuilts/sdk/tools/jack-admin start-server

あとはビルドが終わるまでひたすら待ち。Pixelデバイスが手元に無いので動作確認すら取れない。どうしよう…買うか…?

aurヘルパーyayの導入

長らくyaourtを使っていたが、どうもディスコンのようなので。

$ mkdir ~/yay &amp;&amp; cd ~/yay
$ git clone https://aur.archliunx.org/yay.git
$ cd yay
$ makepkg -si

基本的にはこれで終了。もし既にaurヘルパーがいるなら、それを使うとらくちん。

$ yaourt -S yay
$ yay -Rs yaourt

新規環境でいじるときとか、base-develを入れ忘れていると「Cannot find the strip binary required for object file stripping.」とか怒られるのでお気をつけて。

LinuxでGoogle Keepのデスクトップクライアント

あると便利かな〜と思って検索していたら発見したので使ってみる。 https://github.com/andrepolischuk/keep Releaseにあるバイナリを使ってもいいんだけど、折角なので(?)cloneして使ってみる。

$ git clone https://github.com/andrepolischuk/keep.git
$ ./keep
$ npm install
$ npm start

うまくいけばこれで起動できる。んで、あとは普通に使える。 さて、このままだと起動しにくいので起動スクリプトでも用意しておこう。ランチャでdmenuを利用しているので(Super+Rでdmenuを起動するようにしてあるので諸々の起動が楽)、パスが通った場所に起動スクリプトを置いておけると便利だ。

$ cat /usr/local/bin/keep-client
#!/bin/bash

cd ~/keep
npm start

わざわざ記事に書くまでもない感じの内容だった…。

LinksMateを契約した

メインとして使っているドコモ回線の高速通信容量を使い潰すと、128kbpsというマジで使い物にならない速度に落ちてしまうのでとても厳しい。

この状態になるとブラウジングは当然まともにできないし、アプリの通信だってタイムアウトしまくり。(ようわからんがツムツムは通信するデータが少ないみたいで、速度制限下でもそれなりに快適にプレイできていた)

という訳で、逃げの回線としてexciteの最適料金プランを用意した、というのは以前書いた通り。でも、不満が出てきた。主には以下の2つ。

当時はドコモ回線の高速通信容量を使い潰すのは稀だろうと思っていたので、逃げの回線を使うかどうかはわからんな、と思っていた。だから使わない時には安く抑えたいという気持ちが強く、最適料金プランが結構適しているなという判断だった…が、蓋を開けてみると、マジで毎月通信制限食らう状況であった。つまり、どうせ毎月使うのであれば、使わない時には安いという利点を活かせない。

もう一つの不満は通信速度。トイレに篭っているときとか、待てばゼロ円的な漫画アプリを使う事が多いのだけど、まともに読めない。読み込み待ちとか失敗とかで、全然読み進められない。通信制限されたドコモよりは幾分マシだけど…みたいな感じ。

という訳で、それなりに安くて、実績の通信速度がそれなりに出るという方向で探してみると、LinksMate案外良いじゃんという結論になった。

カウントフリーオプションとかゲームへの特典とかが目に入りがちだが、自分の使い方ではそちらの利点は一切得られない。なんてことだ…

でも、速度比較とか見てると、かなりの実測値が出ているようだ(直近7日間の実効速度を公式で出している)。どうもゲーム等のインセンティブがあって、LinksMate自体は赤字でも、ほか事業の収益的には問題ないらしいみたいな記事をどこかで見たけど、ありがとうございますの気持ちしか生じないな。ゲームもコンテンツも利用しない自分は完全に赤字顧客なので。

という訳で契約しました。Amazonで350円で売ってるコードを入力すると契約事務手数料が0円になるらしいので、それを利用して契約。

実際の利用感とかはまた後日〜

ConoHaのVPSでArchLinuxを使う

そもそもの動機は単純で、PCを持ち込んではいけないというルールがある現場におり(仕事)、昼休みを無為に過ごす事しかできない…しかし、「PC」なので、あぁスマホやタブレットは持ち込み可なんですね、という話になる。事実スマホは使い放題だし(それはそれで問題があるような気もする)タブレットを弄っている人は見たことないけど、iPad弄ってたって怒られなかった さて、iPadが現場で使えるという事は確認できたが、iPadで直接開発作業を行うのは厳しい。お手軽に使えるターミナルエミュレータはパッと探した所見つからなかったし、何より自分はいまのとこNode.jsを使いたいので厳しい。という訳で、出先から適当なサーバにSSHで接続して開発をすれば良いのだ!という展開になる。 適当なサーバという事で、まぁ真っ先に自宅サーバが候補に上がるのだが、どうせならやったこと無いことしよ!と思い立って、VPSにを利用することにした。必要になったら好きにスペック上げ下げできるみたいだし、ストレージ欲しいな〜〜〜〜と思ったら適当にオブジェクトストレージ契約したりすれば良いのだ。 VPS業者の選定だけど、何も考えずサクッとArchLinuxが使える、ということでConoHaに決定。Vultrとかは自前でISOイメージうpしてそこから〜とかやれるみたいだが、やはり楽ちんである事は大切だよ。 さて〜、画面に従っててきとうに作ればもう使える状態のArchLinuxが出現するので、状態確認とか初期設定を行っていこう。今回は1GBプランを利用。ISOは20180914版。 自分でインストールする時って、パーティショニングとロケール、タイムゾーン、ブートローダあたりが最小限かな?というわけでその辺の現状をまずは見てみる。

# lsblk

NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT

sr0     11:0    1 1024M  0 rom

sr1     11:1    1  482K  0 rom

vda    254:0    0   50G  0 disk

├─vda1 254:1    0    2M  0 part

└─vda2 254:2    0   50G  0 part /

# mount | grep vda
/dev/vda2 on / type ext4 (rw,relatime)
# free -h

              total        used        free      shared  buff/cache   available

Mem:          988Mi        48Mi       762Mi       0.0Ki       178Mi       797Mi

Swap:         2.0Gi          0B       2.0Gi

容量関係を見ると、/に全振り。ファイルシステムはext4だそうだ。GUIも何も無いので起動直後のメモリ使用量は48MiBとマジで軽い。メモリがそんなに無いからなのか、Swapは2倍量確保している。上のプランだとまた違う容量になるのかは不明。

# cat /etc/locale.gen | grep -v ^#

en_US.UTF-8 UTF-8

# ls -l /etc/localtime

lrwxrwxrwx 1 root root 30 May 29  2015 /etc/localtime -> /usr/share/zoneinfo/Asia/Tokyo

# uname -a

Linux archlinux 4.18.6-arch1-1-ARCH #1 SMP PREEMPT Wed Sep 5 11:54:09 UTC 2018 x86_64 GNU/Linux

ロケールはen_US.UTF-8のみなので、ja_JP.UTF-8も有効にしておくか。取り敢えずssh鍵の設置が終わってからで…。タイムゾーンはデフォルトでAsia/Tokyoになっている。ま、VPSそのものが東京リージョンだし、これで変なとこだったら意味わからんでしょ。ついでにカーネルバージョンも確認しておいた。あんま気にしてないけど。

# ls /boot
grub  initramfs-linux-fallback.img  initramfs-linux.img  vmlinuz-linux

最後に、ブートローダはgrub(grub2)でした。 以上、取り敢えず状態確認はお終い。次は初期設定を行うぞ。一般作業ユーザを作って、以降はそこから作業しよう。んで、さっさとSSHでつなげるようにしよう。
Web上のコンソールからではしんどい
Web上のコンソールからではしんどい

# useradd -m -g wheel tea
# passwd tea
# pacman -S sudo
# visudo
# su tea
$ id
uid=1000(tea) gid=10(wheel) groups=10(wheel)

以降一般ユーザで作業…と言っても、あとは普通のサーバだと思えば、素直にセットアップすれば宜しい。というわけで以下略。な〜んにも難しいことや新しい事はなかった。 今後ずっとこれを使っていくかはちょっと微妙。お金が貯まったらRyzenで1台組もうと思っているので、それで代替しようかな〜と思っている。やっぱ手元にマシンがあった方が楽しいよ。

WordPress5でAmazonJSを使う

気付いたらエディタが前のやつからブロックエディタに変わっていてびびった上に、AmazonJSをどこで呼び出すのかわからなかったのでメモ。

Wordpress5になって、以前はプラグイン扱いだったGutenbergというのがデフォルトで使われるようになったらしい。まぁ使い勝手も良いし楽しいので良いのだけど、AmazonJSが使えなくなるのはかなしい。というわけで使い方。

つかいかた

  1. ブロックを用意する
  2. ブロックタイプを「クラシック」にする
  3. 以前まで使えていたエディタが表示される
  4. AmazonJSを呼び出せそうなアイコンがあると思うので、あとは従来どおりに
単純な話でした。ブロックエディタを使いたくてこんな記事を書いているというのもある。