Proof-of-Authority?  僕の真似か...


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

合意形成は,peertopeer取引に必須です.サトシナカモトが,Bitcoinの概念を発表してから,信頼に足るトランザクションを可能にする仕組みが出来上がりました.

この概念から,合意形成モデルであるProof-of-Workが生まれました.Proof-of-Workは複雑なアルゴリズムを解くことを必要とし,膨大な量の電力と計算能力を消費します.

Proof-of-Workは,個人的なマイニングが参入することが難しくなるようなハイスペックな専用の機械の登場によって,合意形成モデルを必要としました.そこで,ユーザーフレンドリーな合意形成モデルであるProof-of-Stakeが登場しました.でも問題がないわけではなく,早期の参入者がネットワークをサポートすることに大きなインセンティブを持つという問題を抱えています.それは,新規参入者が増えないということです.

Proof-of-Authorityが登場しました.このモデルは,個人の身元をネットワークで検証することで,合意形成します.参入者は,ネットワークを検証して報酬を受け取る権利と引き換えに,個人の身元を確認されます.参入者がのテストとスクリーニングを通され,ネットワークトランザクションの検証に参加できるようになります.

Proof-of-Authorityは,プライバシーと匿名性に焦点を当てている暗号通貨コミュニティの当初の目的と矛盾するように思われますが,我々はBlockchain技術の実用的な応用が,データの分散性であることを思い出してください.実はこれに似たことを僕は考えています.

コンテナをテスト

未来を変える仮想通貨を作っていこう

sachio@sachio-VirtualBox:~/Project/mpos-zeny-docker$ sudo docker run -it -p 80:80 -p 3333:3333 sgs01115/mpos-zeny-docker
sed: can’t read /etc/php5/apache2/php.ini: No such file or directory
=> Using an existing volume of MySQL
Traceback (most recent call last):
File “/usr/bin/supervisord”, line 6, in
from pkg_resources import load_entry_point
File “/usr/local/lib/python3.6/dist-packages/pkg_resources/init.py”, line 3241, in
@_call_aside
File “/usr/local/lib/python3.6/dist-packages/pkg_resources/init.py”, line 3225, in _call_aside
f(*args, **kwargs)
File “/usr/local/lib/python3.6/dist-packages/pkg_resources/init.py”, line 3254, in _initialize_master_working_set
working_set = WorkingSet._build_master()
File “/usr/local/lib/python3.6/dist-packages/pkg_resources/init.py”, line 583, in _build_master
ws.require(requires)
File “/usr/local/lib/python3.6/dist-packages/pkg_resources/init.py”, line 900, in require
needed = self.resolve(parse_requirements(requirements))
File “/usr/local/lib/python3.6/dist-packages/pkg_resources/init.py”, line 786, in resolve
raise DistributionNotFound(req, requirers)
pkg_resources.DistributionNotFound: The ‘supervisor==3.3.1’ distribution was not found and is required by the application

円のアップグレード


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

みずほ銀行が3月1日から開始した,日本のキャッシュレス化を促進するためのサービスJ-Coin Payですが,これは暗号通貨ではなくて ,デジタル通貨です.ブロックチェーン技術も用いられていません.

みずほ銀行は,他のデジタル通貨とも連携し,そこに暗号通貨が導入される予定です.これは当然のことながらBitcoinやEthereumなどの主流のデジタル通貨ももちろんですが,MonaCoin,NEM,Rippleなどの暗号通貨にも有効になるでしょうか.

また,クレジットカード会社や,このプロジェクトに参加していない国内の銀行にとっては負の要素が強いでしょう.

私は経済学には疎いのですが,何となく景気の転換点に来ているのはわかります.円が近い将来デフレや潜在的な世界経済の不安定化に対抗するために,日本の成長戦略の一つとして注目していますが,今のところ何も変わってないように思います.

BitGo


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

BitGoについて知っていますか?BitGoは暗号通貨を用いないブロックチェーンのサービスです.BitGoはサービスとソリューションを提供し,それらに課金するという伝統的なビジネスモデルを追求しています.

例えば,Webウォレットとしてすべてのサービスを提供するAPIを提供します.それは新しく何かを始めたい人にプラットフォーム,ゲーム,そして電子商取引ソリューションにBitGo APIを用いることができるということです.使ってみてもいいかなぁと思います.

ゲーム会社はそのプラットフォームにBitGo APIを組み込んで,様々な暗号通貨を受け入れることができます.逆に,このAPIはゲームプレーヤーにBitGo APIプラットフォームへのアクセスを提供します.

BitGoは,銀行に似ていますが,成功すれば,BitGoは成長し,世界最大のBitcoin(BTC)の取引ができると主張しています.実際,Bitgoは,Bitcoinの全取引の15%を処理していると主張しています.

さらに,BitGoは1カ月あたり150億ドルの暗号通貨を処理し,20億ドルの暗号通貨資産を保有していると主張しています.ただし,BitGoは暗号通貨の取引所ではありません.

ただし,BitGoは,少なくとも米国で最初の本当の暗号通貨銀行になるための基礎を築きはじめています.そのため,BitGoは金融業界にサービスを広げています.ゴールドマンサックスはその後ろ盾です.

BitGoはブロックチェーンサービスを販売しています.それは,プライベートブロックチェーン,API,および他の組織への暗号通貨の保管を含んでいることによって金融そのものを扱うことができるのです.このようなサービスは日本でもありそうですが,プライベートにしたときに,失われるスケーラビリティに私は疑問を感じます.

Mint Royal Mint GoldもBitGoは支えていきます.このように大規模なブロックチェーン取引インフラストラクチャの基礎を築いているため,BitGoha,暗号通貨とブロックチェーンの将来になる可能性があります.

ブロックチェーンが主流になるには,BitGoの失敗または成功によって明らかになると思いますが,それは私たちの考えている,公平と公正というブロックチェーンと異なります.サーバとクライアントで出来そうですし.

Facebookと暗号通貨


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

世界最大のソーシャルネットワークは,あなたの人生を知ってると言ってもいいでしょう.Facebookは,あなたがあなたのお金をどのように使うかを知りたいのです.

驚くべきことですが,Patrick Tanによれば,ある女性が妊娠した時に彼女の父親が遠方にいたのにもかかわらず,彼女の父親の広告枠にマタニティ関係の広告が埋められていたことに気づいたのです.父親は自分の妻が妊娠していないことを知っていたので,娘に会いに行ったそうです.

言うまでもなく私たちのFacebookやGoogleアカウントを使ってウェブサイトにログインすることによって残されたクッキーは,私たちのオフライン生活に関するデジタルの痕跡と手がかりを残します.

彼らは,私たちをみています.

宣伝や広告をターゲットにしているかどうかにかかわらず,私たちがインターネットへ流出するデータは,Google,Facebook,Amazonなどが,必要以上のものを購入させたりします.

私は,利便性という観点からプラットフォーム自体は問題ないと思います.

それでもFacebookが米ドルに裏打ちされた独自の暗号通貨を発表するという報道は,危険な感じがしました.

それは,サトシ・ナカモトの想いとそれが構築したオープンソースのブロックチェーンとどのように関わるかはわかりませんが,彼らが,その想いをわかるでしょうか.

Facebookは,なんと15億人のユーザに裏付けされた暗号通貨に基づく支払いシステムを完成させるために多くの金融会社と商品提供者と手を結ぼうとしています.

これは,トークンが最終的に使われるプラットフォームを既に持っていることを意味しています.

非常に多くのWebサイトでユーザーが自分のFacebookアカウントを使用してログインしていることは,最終的に彼らの利益になるでしょう(管理コストの問題が解決すればですが).

そしておそらくFacebookのユーザーがこれらのコインを受け取ったら,彼らはそれを使って広告主自身が提供する商品やサービスの代金を支払うことができるでしょう.まさにFacebookの言うがままです.

ただし,Facebookが発行した暗号通貨が基軸通貨に基づいていなければならないでしょう.

でも,負の面だけではないかもしれません.

例えば,クレジットカードがいらなくなります.これは,これは発展途上国では有効でしょう.

それでも,Facebookは,分散型の平等主義の世界を目指すことはないように思えます.

中国のAlibabaやTencentのような企業は,すでに,中国の銀行やクレジットカード会社よりも強力です.ですから,Facebookが独自の暗号通貨を開発することを推進してきたことは驚くべきことではないはずです.

プラットフォームとしてのFacebookが,世界の民主主義において,その存続をテクノロジで揺さぶる可能性があるとしたら,私たちの個人的な生活にまで影響を与えることができるでしょう.そうなったとき,分散化の利益、ブロックチェーンの存在意義は失われてしまいます.

これは,怖いことです.

Windowsネイティブなマイニングプールを作ってDockerで動くかな 中止 からの 追記①


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

これまで,UbuntuでDockerを使って,マイニングプール(mposなど含む)を作っていくことをひたすら試行していたのですが,うっかり忘れていました,本来の趣旨は,Windowsで作るってことでしたので,これだと結局Ubuntuで作っているのと全く変わらないのではないかと.

そこで,Windowsネイティブなマイニングプールを作ってDockerで動かすこと試していきます.まず,普通にマイニングプール動かすところまでいかねば...Dockerもよくわかったし,Windows版はライセンスが問題あるかと思うのですが,やってみてもいいでしょうか...

https://github.com/coinfoundry/miningcore

に,マイニングプールを作ってくれるWindows版あったので,これを使ってみます.やることは,このgitに書いてあります.やってみましょう.公開しながら,書き加えていきます.

https://www.atmarkit.co.jp/ait/articles/1702/02/news039.html

で,自分の環境では無理と判明...でっ

Windows版DockerとUbuntuで製作中です。

FROM ubuntu:latest
MAINTAINER SachiO
RUN rm -rf /usr/sbin/policy-rc.d ADD policy-rc.d /usr/sbin/policy-rc.dRUN chmod +x /usr/sbin/policy-rc.d
ADD bitzenyd /bin/bitzenydRUN chmod +x /bin/bitzenyd
RUN mkdir /root/.bitzenyd \ && mkdir /root/.bitzenyd/testnet
ADD bitzeny.conf /root/.bitzent/bizeny.confADD wallet.dat /root/.bitzeny/testnet/wallet.dat
ENV APACHE_RUN_USER="www-data" \ APACHE_RUN_GROUP="www-data" \ APACHE_PID_FILE="/var/run/apache2.pid" \ APACHE_RUN_DIR="/var/run/apache2" \ APACHE_LOCK_DIR="/var/lock/apache2" \ APACHE_LOG_DIR="/var/log/apache2" \ APACHE_USER_UID="0" \ DEBIAN_FRONTEND="noninteractive"
RUN apt-get update -qq \ && apt-get install -y apt-utils perl --no-install-recommends RUN apt-get install -qqy --force-yes \ build-essential \ apache2 \ cron \# libapache2-mod-php \ supervisor \ curl \ openssh-server \ libboost-all-dev \ libcurl4-openssl-dev \ libdb5.3-dev \ libdb5.3++-dev \ mysql-server \ git
RUN apt-get -y update \ && apt-get -y upgrade \ && apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4F4EA0AAE5267A6C \ # && gpg -a --export 4F4EA0AAE5267A6C \ # && apt-key add - \ && apt-get install -y python3.6 \ && rm /usr/bin/python \ && ln -s /usr/bin/python3.6 /usr/bin/python
RUN wget https://bootstrap.pypa.io/get-pip.py \ && python get-pip.pyRUN apt-get install -y python3-pip \ && ln -s /usr/bin/pip3 /usr/bin/pip
RUN apt-get -y purge php* \ && apt -y autoremove \ && apt autoclean \ && apt-get -y install software-properties-common \ && add-apt-repository -y ppa:ondrej/php \ && apt-get -y install php5.6 \ && apt-get -y install php5.6 php5.6-cgi libapache2-mod-php5.6 php5.6-common php-pear# && apt-get install -y libapache2-mod-php5
RUN pip -VRUN rm -rf /etc/apache2/apache2.conf
ADD apache2.conf /etc/apache2/apache2.confADD apache_default /etc/apache2/sites-available/000-default.conf

https://github.com/sgs01115/TestingAdockerForBitZeny

にて,公開中ですので,随時,最初からの説明を書いていきます.

とりあえず...BuildできたmposのDockerfiles


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう
FROM ubuntu-upstart:latest

MAINTAINER  SachiO

RUN rm -rf /usr/sbin/policy-rc.d 
ADD policy-rc.d /usr/sbin/policy-rc.d
RUN chmod +x /usr/sbin/policy-rc.d

ADD litecoind /bin/litecoind
RUN chmod +x /bin/litecoind

RUN mkdir /root/.litecoin \
    && mkdir /root/.litecoin/testnet3

ADD litecoin.conf /root/.litecoin/litecoin.conf
ADD wallet.dat /root/.litecoin/testnet3/wallet.dat

ENV APACHE_RUN_USER="www-data" \
    APACHE_RUN_GROUP="www-data" \
    APACHE_PID_FILE="/var/run/apache2.pid" \
    APACHE_RUN_DIR="/var/run/apache2" \
    APACHE_LOCK_DIR="/var/lock/apache2" \
    APACHE_LOG_DIR="/var/log/apache2" \
    APACHE_USER_UID="0" \
    DEBIAN_FRONTEND="noninteractive"

RUN apt-get update -qq \
    && apt-get install -y apt-utils perl --no-install-recommends

RUN dpkg-divert --local --rename --add /sbin/initctl \
    && ln -s /bin/true /sbin/initctl

RUN apt-get install -y software-properties-common \
    && apt-get install -y software-properties-common python-software-properties \
    && apt-get -y update \
    && apt-get -y upgrade \
    && apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4F4EA0AAE5267A6C \
    # && gpg -a --export 4F4EA0AAE5267A6C \
    # && apt-key add - \
    && add-apt-repository ppa:jonathonf/python-3.6 \
    && apt-get -y update \
    && apt-get install -y python3.6 \
    && add-apt-repository ppa:ondrej/php \
    && apt-get -y update \
    && apt-get -y upgrade \
    && apt-cache policy php5.6 \
    && apt-get install -y  libapache2-mod-php5 \
    php5-memcached \
    php5-mysqlnd \
    php5-curl \
    php5-json \
    && apt-get install -qqy --force-yes \
    build-essential \
    apache2 \
    cron \
    pwgen \
    supervisor \
    curl \
    openssh-server \
    libboost-all-dev \
    libcurl4-openssl-dev \
    libdb5.3-dev \
    libdb5.3++-dev \
    git \
    memcached \
    && add-apt-repository ppa:deadsnakes/ppa \
    && apt-get install -y mysql-server-5.5 \
    && apt install -y mysql-server \
    mysql-client
RUN python -V

RUN wget https://bootstrap.pypa.io/get-pip.py \
    && python get-pip.py \
    && python3 get-pip.py

RUN python -V \
    && rm /usr/bin/python \
    && ln -s /usr/bin/python3.6 /usr/bin/python \
    && python -V \
    && ln -s /usr/bin/pip3 /usr/bin/pip

RUN pip3 install -U distribute \
    && pip install -U distribute \
    && rm -rf /etc/apache2/apache2.conf

ADD apache2.conf /etc/apache2/apache2.conf
ADD apache_default /etc/apache2/sites-available/000-default.conf

RUN cd /var/www \
    && git clone git://github.com/MPOS/php-mpos.git mpos \
    && cd mpos \
    && python -V \
    && git checkout master \
    && chown -R www-data templates/compile templates/cache logs \
    && cd /root \
    && python -V \
    && git clone https://github.com/ahmedbodi/stratum-mining.git \
    && cd /root/stratum-mining \
    && python -V \ 
    && git submodule init \
    && git submodule update \
    && cd /root/stratum-mining/externals/litecoin_scrypt \
    && python -V \
#    && apt-get install -y python-dev \
    && apt-get install -y python3-dev \
#    && export CPATH=$CPATH:/usr/include/python2.7/ \
    && export CPATH=:/usr/include/python3.6/ \
    && printenv \
    && python -V \
    && python3 setup.py install \
#    && python2 setup.py install \
    && cd /root/stratum-mining/externals/stratum \
    && printenv \
    && python -V \
    && python3 setup.py install \
#    && python2 setup.py install \
    && mkdir /root/stratum-mining/log

ADD config.py /root/stratum-mining/conf/config.py
ADD global.inc.php /var/www/mpos/include/config/global.inc.php
ADD start-apache2.sh /start-apache2.sh
ADD start-mysqld.sh /start-mysqld.sh
ADD start-cron.sh /start-cron.sh
ADD start-litecoind.sh /start-litecoind.sh
ADD start-stratum.sh /start-stratum.sh
ADD start-memcached.sh /start-memcached.sh

ADD run.sh /run.sh
RUN chmod 755 /*.sh

ADD my.cnf /etc/mysql/conf.d/my.cnf
ADD supervisord-apache2.conf /etc/supervisor/conf.d/supervisord-apache2.conf
ADD supervisord-mysqld.conf /etc/supervisor/conf.d/supervisord-mysqld.conf
ADD supervisord-cron.conf /etc/supervisor/conf.d/supervisord-cron.conf
ADD supervisord-litecoin.conf /etc/supervisor/conf.d/supervisord-litecoin.conf
ADD supervisord-stratum.conf /etc/supervisor/conf.d/supervisord-stratum.conf
ADD supervisord-memcached.conf /etc/supervisor/conf.d/supervisord-memcached.conf

ADD cron /etc/cron.d/cron
RUN chmod 0644 /etc/cron.d/cron \
    && chmod +x /etc/cron.d/cron \
    && rm -rf /var/lib/mysql/*

ADD create_mysql_admin_user.sh /create_mysql_admin_user.sh
RUN chmod 755 /*.sh

RUN a2enmod rewrite \
    && service apache2 restart

ENV PHP_UPLOAD_MAX_FILESIZE="10M" \
    PHP_POST_MAX_SIZE="10M"

RUN mkdir /var/run/sshd \
    && echo 'root:root' |chpasswd \
    && sed -ri 's/^PermitRootLogin\s+.*/PermitRootLogin yes/' /etc/ssh/sshd_config \
    && sed -ri 's/UsePAM yes/#UsePAM yes/g' /etc/ssh/sshd_config \
    && sed -ri 's/from autobahn.websocket import WebSocketServerProtocol, WebSocketServerFactory/from autobahn.twisted.websocket import WebSocketServerProtocol, WebSocketServerFactory/g' /usr/local/lib/python2.7/dist-packages/stratum-0.2.13-py2.7.egg/stratum/websocket_transport.py
ADD supervisord-openssh-server.conf /etc/supervisor/conf.d/supervisord-openssh-server.conf

EXPOSE 80 443 3306 22 3333
CMD ["/run.sh"]

Windows 10 Home, Docker Toolbox

ちょっとした嘘


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

AIについてのちょっとした嘘

AIのブームはいつまで続くでしょうか.AIは確かに,世界を革命的に変化させるような力を持つように見えます.ただし,その技術は誇張されているかもです.
実は,AIを名乗る企業でも本当に革新的なAIテクノロジを駆使しているわけではありません.つまり自称人工知能なのです.彼らは,既存のソフトウェアにAIを付加的に用いて,ソフトウェアをより興味深く見せるための道具としてAIを使用しています.
例えば,チャットボットは,大手企業のライブラリやAPIを使用して対話を作成したり,キーワードの探索して対話します.ここで使われるAIは,大企業で学習済みのデータ・ライブラリを使用しているだけです.時には,単なるデータベースを使うことさえあります.
もっと言えば,AIがこなしているように見せかけても,人が作業している場合もあります.
このようなからくりは,どうしたら見破れるでしょうか?,単純にサービスが,安い,AIの専門家がいない,機械学習に利用できる大きなデータを持っていないことを見ればよいでしょう.

ブロックチェーンのちょっとした嘘

ブロックチェーンは,おそらく人工知能に次いで,ブームになっています.ブロックチェーンを扱う世界は,本当に小さなギークの集団から,何千億もの時価総額を持つ世界的な業界へと急速に成長しました.
ブロックチェーンを用いた暗号通貨の開発がオープンソースであり,この性質により,この業界は一気に世界規模に進出することが可能になりましたが,そこには,少しばかり?!の嘘もあります.
ほとんどのICOは機能していないのが現状です.つまり大多数は成功していないのです.

何が正しいの?

皆さん知りたいですよね.経済的に成功している国の指導者たちを見ると,絶望感があるかもしれません. 嘘はときには.人々が未来に進むのを手助けしているように見えます.技術の進歩は,多くの情報と機会を私たちに与えてくれて,民主化を進めるための最も公正な方法でだと私たちは考えます.少なくとも私たちは,人類の未来を本当に気にかけているのです.それこそ,トラストレスに...

ビルド成功です...次回からはcoindで


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

今回は,相当ハマりました.ハマりどころは,まず...

1)サンプルとしていたnrpatten/mpos-docker のベース・イメージが旧かったので,ベースイメージを変更するのに手間取った,

これは,いろいろ試した結果, ubuntu-upstart にしました.その結果,追加する場所が増えました.

・apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4F4EA0AAE5267A6C
・apt-cache policy php5.6

です.この二か所を追加するのに結構訳が分からなくなりました.地道にエラーを潰す感じです.またイメージを変えたことでVirtualBoxのストレージ容量を大きくする必要がありました.

2) python3を入れることを忘れていた.

3)鬼のような依存関係...

4)Docker Quickstart Terminalが,DNSをしばしば見失う.

たった二つのことを潰すのに,すげぇ手間が要りました.かなり勉強になりました.次回からは,coindでイメージを作ります.また,ハマりどころをお知らせします.

Successfully built 153125192b11
Successfully tagged nrpatten/mpos:latest

合意形成と障害


https://bitcoin20xx.xyz/未来を変える暗号通貨を作っていこう

分散システムアプローチ

Casper CBCは,分散システム問題として合意形成の問題に取り組んでいます.

まずはじめに,分散システムにおける障害とは,なんでしょうか.

コンセンサスメカニズムの前提は,「障害の数が十分に少なければ,すべて問題ない」ということです.これは,「十分に障害がある場合にのみ,問題が発生する」と言い換えることができます.

コンセンサスメカニズム

さて,わかりにくい専門用語に慣れましょう.

バリデータ:合意を形成するノードのことをバリデータと呼ばれます.
メッセージ:メッセージは、合意に達することを試みる努力の中でバリデータによって生成され伝えられます.

メッセージ

メッセージは,合意形成プロセスに参加している間にバリデータによって生成され,伝えられる情報です.Casper CBC合意形成メカニズムでは,メッセージは以下の構造を持ちます.

メッセージ構造 =(値、バリデータ、正当化)

メッセージ構造を説明します.

値:値は,バリデータが合意に達するようにネットワークに提案する値のことです.
バリデータ:これはメッセージを生成しているバリデータです.
正当化:メッセージの正当化は,バリデータがその特定のメッセージを生成している間に確認および確認した一連のメッセージです.後で見るように,その正当化は提案された値を文字通り「正当化する」ことになっています.

ここで,メッセージに関わる2つの重要な概念を見てみましょう.

後のメッセージ:メッセージAがメッセージBの正当性を説明するものである場合,メッセージBはメッセージAよりも後になります.
推定関数:推定関数は,正当化を入力として,入力によって「正当化された」値を返します.

合意規則

提案された値は,正当化に対する推定関数の適用によって返された合意形成値と同じでなければなりません.
バリデータは2つのメッセージを作ることができないようになっています.

合意規則違反

バリデータが,受け取ったメッセージの時点差により,分離されるかもしれません.

意思決定保証

十分な数のバリデータが提案する有効な値を含むメッセージを作成した後に,多数のバリデータがフォルトを生成することなしに矛盾する値について合意形成することは不可能であることを合意規則は保証します.

したがって,十分な数のバリデータが有効な値を含むメッセージ見た後で,ノードは合意値を決定します.この「十分に高い」数は、そのノードのフォールトトレランス閾値によって異なります(この十分という部分は未定義です).