2019年8月16日金曜日

git

gitは、web上のプロトコルでなくても、ローカルのファイルシステムでも動作する。
動作確認は、ローカルのファイルシステムで行うのが簡単

$mkdir base.git
$cd base.git
$git init --bare --shared
$cd ..
$git clone --bare --shared base.git second.git

$ git clone base.git test0
Cloning into 'test0'...
warning: You appear to have cloned an empty repository.
done.

$cd test0
$ git remote set-url --push origin ../second.git
$ git remote -v
origin /home/ok/git_test/base.git (fetch)
origin ../second.git (push)

$ echo 'first commit' >  a
$ git add .
$ git commit -m 'first commit'
[master (root-commit) 8c08e8e] first commit
 1 file changed, 1 insertion(+)
 create mode 100644 a
$ git push
Counting objects: 3, done.
Writing objects: 100% (3/3), 212 bytes | 212.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To ../second.git
 * [new branch]      master -> master

2019年4月5日金曜日

ubuntu kernel build

apt でソースがダウンロードできるように
sudo sed -i 's/^# deb-src/deb-src/g' /etc/apt/source.list
source.listのdev-srcのコメントをはずす。
修正したら
sudo apt update

linuxビルドに必要なものをインストールする。
sudo apt install ccache fakeroot libncurses5-dev
sudo apt build-dep linux

sourceの取得
apt source linux
で取得できるが
NOTICE: 'linux' packaging is maintained in the 'Git' version control system at:
git://git.launchpad.net/~ubuntu-kernel/ubuntu/+source/linux/+git/bionic
Please use:
git clone git://git.launchpad.net/~ubuntu-kernel/ubuntu/+source/linux/+git/bionic
上記の方法で取得したubuntu kernelは、下記の方法ではビルドできない
若干の修正が必要

git で取得しろとのこと
git clone https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git

cd linux
mkdir ../build
cp /boot/config-`uname -r` ../build/.config

make O=../build/ olddefconfig

カーネルビルド
make -j9 O=../build/ LOCALVERSION=-xxx

モジュールビルド
make modules -j9 O=../build/ LOCALVERSION=-xxx


パッケージ作成
make bindeb-pkg O=../build/ LOCALVERSION=-xxx
bindeb-pkg バイナリパッケージのみ
deb-pkg ソースパッケージも作成

インストール
sudo apt ../*.deb



build 時間
core2 duo

real    190m49.470s
user    310m50.655s

sys     36m25.217s

Intel(R) Core(TM) i3-6100U CPU @ 2.30GHz
real 115m21.085s
user 166m20.077s
sys 17m37.104s

Intel(R) Pentium(R) CPU G4620 @ 3.70GHz
real 51m28.830s
user 185m58.351s
sys 15m43.776s

Intel(R) Core(TM) i7-9700 CPU @ 3.00GHz
real 20m22.547s
user 113m49.728s
sys 11m31.246s

lxd環境
real 1087.78  18m7.78
user 7239.94    120m39.94
sys 874.63           14m34.63









2019年1月13日日曜日

php apache postgresql ubuntu18へのインストール

apache2 とphp のインストール
#apt install php
これだけ
/var/www/html/phpinfo.php
を作って 動作確認をしてみる
phpinfo.phpは
<?php phpinfo() ?>

postgresのインストール
#apt install postgresql
インストールしたらpostgresのパスワード設定をする
#su - postgres
$psql
postgres=# \password
Enter new password:
Enter it again:
postgres=# \q
$exit
#
phppgadminのインストール
#apt update
#apt install phppgadmin
そのままでは、外部からアクセスできないので
/etc/apache2/conf-available/phppgadmin.conf
を修正
Require local => Require all granted
/etc/phppgadmin/config.inc.php
を修正
$conf['extra_login_security'] = false;
apache2再起動
#systemctl restart apache2
http://xxx.xxx.xxx.xxx/phppgadmin
をアクセスして動作確認




2019年1月11日金曜日

lxd containerに関するメモ

container  ubuntu18

lxdはlxcを使いやすくしたもの

インストール
sudo apt instasll lxd
snap install lxd

初期化
lxd init
いろいろ設定項目があるが、すべてdefaultで大丈夫
 
下記のエラーが出力される場合は、
 Error: Failed to connect to local LXD: Get http://unix.socket/1.0: dial unix  /var/snap/lxd/common/lxd/unix.socket: connect: permission denied

idコマンドでlxdグループが追加されているか確認し、
ない場合は、
usermod -aG lxd USER名
でグループを追加しlogoff/loginする。(exec $SHELL -l)


コンテナの作成
lxc launch ubuntu:18.04 ub18  
 (lxc launch ubuntu:20.10 ub201)
  ub18は、任意のコンテナの名前

コンテナのリスト表示
lxc list
コンテナのイメージのリスト
lxc image list
コンテナの情報
lxc info コンテナの名前

コンテナの起動 lxc start ub18

コンテナの接続 lxc exec ub18 -- bash

コンテナの停止 lxc stop ub18
コンテナの削除 lxc delete ub18


lxc file pull
lxc file push

fedora28のイメージをダウンロードしてコンテナを作るのは
lxc launch images:fedora/28/amd64 fe28

snapshotの作成
lxc snapshot ub18 20190120

コンテナ内のウエブサイト等を外部に公開する。
host側のnicに公開用のaddressを追加
ip a add 192.168.0.88/24 dev enp0s10
公開用のアドレスとコンテナのアドレスを接続する。
sudo iptables -t nat -A PREROUTING -p tcp -d 192.168.0.88 -i enp0s10 --dport 80 -j DNAT --to-destination 240.82.0.47:80

リモートサーバ名
lxc remote list

イメージのリスト
lxc image list ubuntu:

LXD にはデフォルトでイメージを提供するリモートサーバが 3 つ登録されています:

ubuntu: (stable Ubuntu イメージ用 )
ubuntu-daily: (daily Ubuntu イメージ用 )
images: (その他の多数のディストリビューション用)

イメージの作り方
snapshotを作成してpublishする。


ホストとターゲットの共有フォルダの作成
lxc config device add container-name home disk source=/home/share path=/home/share
homeは適当な名前
/home/shareは適当なディレクトリ


sshを使う場合

/etc/ssh/sshd_config
を編集
PasswordAuthentication yes
とし
systemctl restart sshd


lxd -h
  activateifneeded   Check if LXD should be started
  help               Help about any command
  import             Import existing containers
  init               Configure the LXD daemon
  shutdown           Tell LXD to shutdown all containers and exit
  version            Show the server version
  waitready          Wait for LXD to be ready to process requests

lxc -h
  alias       Manage command aliases
  cluster     Manage cluster members
  config      Manage container and server configuration options
  console     Attach to container consoles
  copy        Copy containers within or in between LXD instances
  delete      Delete containers and snapshots
  exec        Execute commands in containers
  export      Export container backups
  file        Manage files in containers
  help        Help about any command
  image       Manage images
  import      Import container backups
  info        Show container or server information
  launch      Create and start containers from images
  list        List containers
  move        Move containers within or in between LXD instances
  network     Manage and attach containers to networks
  operation   List, show and delete background operations
  profile     Manage profiles
  project     Manage projects
  publish     Publish containers as images
  remote      Manage the list of remote servers
  rename      Rename containers and snapshots
  restart     Restart containers
  restore     Restore containers from snapshots
  snapshot    Create container snapshots
  start       Start containers
  stop        Stop containers
  storage     Manage storage pools and volumes
  version     Show local and remote versions