blog.monophile.net

コンピュータのこととかのメモ。

山本 一彰 | Takaaki Yamamoto

東京工業大学において計算機科学と応用数学を学び、 情報科学芸術大学院大学[IAMAS]においてメディア表現を専攻し修了。 2015年にコンビネータ論理を基に計算完備な計算手法 "論理珠算"を開発し、 それを含む体系である"算道"を構成した。 その成果により、 第19回 文化庁メディア芸術祭 アート部門 新人賞 (文部科学大臣賞) を2016年に受賞。 現在はインフラエンジニアとして生計をたててている。

技術

Configuration Management Ansible, Terraform, Cloud-Init
Cloud Platform GCP, AWS, Azure, OpenStack
Virtualization, Container QEMU+KVM, Xen, LXD/LXC, Docker
OS Ubuntu, Debian GNU/Linux, CentOS, FreeBSD, ...
Storage Ceph, GlusterFS, ZFS, btrfs, ...
Router Linux+Netfilter, Quagga, VyOS, Cisco IOS, YAMAHA RTX, ...
Switch Dell FTOS, AlaxalA, NETGEAR, ...
DB MySQL, MariaDB(Galera Cluster), MongoDB
Mail postfix, dovecot, RainLoop
WebApps WordPress, GitLab, MatterMost, Redmine, ...
Monitoring Nagios, Munin, Zabbix, Prometheus, Grafana
Misc Kubernetes/Istio, certbot, dnsmasq, ...

習得中

OS CoreOS(Container Linux), Windows on QEMU, ...
SQL PostgreSQL, BigQuery, ...
NoSQL CouchDB, ArangoDB, Neo4J, ...
Misc Proxmox, oVirt, MAAS, NFV, ...

投稿

python cProfile の使い方メモ

いきさつ

一般的に、プロファイラなしでプログラムの最適化はすべきではないと言われているので、 使ってみます。 ProfileとcProfileの2種類あるようなのですが、 今回は動作の速いcProfileを使います。

Hello

シンプルにHelloと出力します。

## test.py ##
def hello():
    print "hello"

if __name__ == "__main__":
    hello()

プロファイラをもちいて実行

以下のコマンドでtest.prfが出力されます。

$ python -m cProfile -o test.prf test.py

test.prfを読む

test.prfはバイナリデータなので、普通のページャでは読めません。 したがって、pstatsというモジュールを使います。

$ python -m pstats ./test.prf
Welcome to the profile statistics browser.
./test.prof% stats
Sun Dec 29 21:03:36 2013    ./test.prof

         3 function calls in 0.000 seconds

   Random listing order was used

   ncalls  tottime  percall  cumtime  percall filename:lineno(function)
        1    0.000    0.000    0.000    0.000 test.py:2(hello)
        1    0.000    0.000    0.000    0.000 test.py:2()
        1    0.000    0.000    0.000    0.000 {method 'disable' of '_lsprof.Profiler' objects}


./test.prof%

起動するとshellが立ち上がるので、statsというコマンドを打つと表示してくれます。 表示する行数Nは“stats N”という形で指定できます。 “help COMMAND”で使い方を提示してくれます。

pstatsをモジュールとして使う

以下のファイルをstats.pyとします。

## stats.py ##
import sys
import pstats as ps

p = ps.Stats(sys.argv[1])
p.sort_stats('time').print_stats(10)

そして以下のコマンドを打つと上記とほぼ同等の出力が得られます。

$ python stats.py ./test.prf