Публикации с меткой «linux»

Блог django на хабрахабре

Django Framework / HowTo по continuous integration проекта на Django с помощью TeamCity

Введение


В процессе разработки, создавая новый функционал, всё чаще широкими мазками стал задевать старый код чем разрушал логику его работы. Это заставило всё-таки написать юнит и интеграционные тесты для старого кода и автоматизировать их запуск, т.к. гонять руками все тесты как-то грустно. Как раз вспомнилось недавнее руководство по CI Django в Jenkins и довольно старое по Webtest в Django. В итоге была совершена попытка поднять Дженкинса, но он как-то на моей убунте не взлетел и я грешным делом вспомнил про TeamCity. «Раз уж пишу в PyCharm и нашёл к нему подход, то, наверно, и TeamCity осилю, ведь конторка-то одна!» — подумалось мне… В общем-то я оказался прав, и, пока мне позволяет карма, решил подарить вам ультраполезный (и мегаподробный), в отличие от моего предыдущего, мануал :)

Итого: кому требуется руководство по поднятию интеграционного сервера TeamCity, и тестирование в нём Django проектов c тестами nose и webtest в виртуальном окружении python с автоматическим его (окружения) обновлением — добро пожаловать под кат.

Осторожно! Для работы TeamCity требуется (согласно документации) sun/oracle версия JVM…

Блог python на хабрахабре

Python / Vertaler — кросс платформенный переводчик

Vertaler — переводчик с открытым исходным кодом, позволяющий переводить любой текст в любом приложении, используя Google Translate и Bing Translator.

Преамбула


Изначально программа задумывалась как альтернатива Google Translate Client в Linux. Уже давно пользуюсь этим переводчиком в windows и очень не хватало аналога под linux, все существующие переводчики меня не устраивали в плане функционала и интерфейса.
Пол года назад решил заняться изучением прекрасного языка Python. Попробовал, почитал умные книжки и решил, что лучшее обучение это практика, после чего решил написать программу-переводчик наподобие Google Translate Client.
И вот первая рабочая версия готова, чем и спешу поделиться, заодно выслушать критику, советы и попросить помощи в создании инсталяционных пакетов для linux.

Функционал


  • Версия для Windows и Linux
  • Поддержка более 30 языков
  • Перевод с помощью Google Translate или Bing Translator на выбор
  • Автоматическое определение исходного языка с помощью Bing API
  • Использование горячих клавиш (зажать Ctrl при выделении текста или после выделения два раза нажать на Ctrl)
  • Автоматическая проверка новых версий (только в windows)
  • Запуск вместе с ОС (только в windows)
  • Мультиязычный интерфейс, пока только английский и русский, программа сама определяет локаль ОС, изменить язык в настройках программы пока нельзя


Блог python на хабрахабре

Python / Easy linux management over twitter

Доброго времени суток, дорогие Хабраюзеры.

Этот пост навеян появлением статьи про Twitter бота и всяких свистелок-плясалок для него. Представляю вам свое видение api Твиттера. Добро пожаловать под кат.

Блог python на хабрахабре

Python / [Перевод] Как применять Linux epoll в Python

В статье описывается:
  • Примеры использования блокирующих сокетов
  • Преимущества асинхронных сокетов и Linux epoll
  • Примеры асинхронного использования сокетов через epoll
  • Вопросы производительности
  • Исходный код

Ростислав Дзинько

Теперь Google App Engine SDK доступен на языке Google Go

В данном посте не проявлю особого творчества, просто публикую здесь перевод поста из блога Go Project. Данный пост считаю очень важным, так как это первое нашумевшее серьезное применение этого языка; и хотя язык позиционируется, как средство системного программирования, в данном случае получаем язык для веб разработки на облачной платформе Google App Engine.


ОригиналПост на блоге Go Project


Google App Engine предоставляет надежные, масштабируемые и простые средства для создания веб приложений. Более сотни тысяч приложений хостятся на appspot.com и пользовательских доменах и при этом используют инфраструктуру App Engine. Изначально система была сделана для создания приложений на Python, а в 2009-м году добавилась еще и поддержка языка Java. Сегодня, на Google I/O, мы с восторгом объявляем вам, что следующим будет Go. Сейчас эта возможность обозначена как экспериментальная возможность App Engine, поскольку технология является новой; но при этом команды App Engine и Go в восторге от этого достижения.


Под словами технология новая мы подразумеваем то, что она еще "обкатывается". На сегодняшний день App Engine SDK для Go доступен для загрузки, а скоро будет доступен и для хостинга. Начиная с сегодняшнего для, используя SDK, вы получаете возможность создавать веб приложения, изучать API (а также, язык, если он для вас новый), а также запускать веб приложения локально. Когда будет доступна возможность хостинга, вы с легкостью сможете переместить проект в облако Google.

Если вам невтерпеж, и вы не можете ждать так долго, вы можете стать доверенным тестером. Для этого следует зарегистрироваться, и вы попадете в список тех, кому данная функция будет доступна раньше всех. После периода тестирования, мы откроем эту возможность всем, хотя она и будет еще некоторое время оставаться экспериментальной частью App Engine.

Еще одна классная, но менее очевидная вещь заключается в том, что вам предоставлен очень простой способ взаимодействия с Go. У вам Go может быть даже не установлен, так как SDK содержит компилятор внутри. Просто загрузите SDK, распакуйте, и начинайте писать приложения. Более того, сервер приложений, который входит в состав SDK, предполагает, что вам даже не придется компилировать приложение собственноручно; все до ужаса автоматизировано.

В SDK вы найдете много стандартных API App Engine, написанных в хорошем Go-стиле, включая Datastore, Blobstore, URL Fetch, Mail, Users, и другие. Поддержка остальных API будет добавлена со временем. Вам предоставляется полная поддержка языка Go и почти все стандартные библиотеки, кроме нескольких вещей, которые не имеет смысл использовать в окружении App Engine. Например, нет пакета unsafe, а пакет syscall урезан. (Реализация использует расширенную версию настройки в Go Playground на golang.org.)



Также, хотя go-рутины и каналы присутствуют, когда приложение на Go работает в App Engine, допускает запуск только одного потока в конкретном экземпляре (instance). То есть все go-рутины запускаются в единственном потоке операционной системы и нет никакой возможность использовать параллельность CPU для клиентского запроса. Мы ожидаем, что удастся убрать это ограничение со временем.


Невзирая на мелкие ограничения, это настоящий язык: код выкладывается в форме исходников и компилируется в облаке с использованием 64-битного x86 компилятора (6g), таким образом это первый компилируемый язык, который работает на App Engine. Go в App Engine предоставляет возможность создавать приложения, от которых требуется эффективность использования ресурса CPU.

Если вы хотите узнать больше, читайте документацию (начиная с “Getting Started”). Библиотеки и SDK поставляются в открытых исходниках, которые размещены на http://code.google.com/p/appengine-go/. Мы создали новый список рассылки google-appengine-go; не стесняйтесь связываться с нами по поводу вопросов об App Engine. Трекер задач для App Engine - это место для отправки сообщений об ошибках, связанных с новым Go SDK.

Go App Engine SDK доступен для Linux и Mac OS X (10.5 или больше greater); надеемся, что Windows версия также будет скоро доступна.

Мы хотим выразить благодарность за всю помощь и энтузиазм команды Google App Engine, которая сделала все вышеописанное возможным.



- David Symonds, Nigel Tao, Andrew Gerrand, и остальная часть Команды Go.

Python for SEO

Segmentation fault при использовании pycurl в Linux.

Написал клиенту простейший скрипт с использованием pycurl (я его всегда, кстати, использую), который состоит буквально из одного get-запроса, а при использовании этого скрипта под Linux, начала периодически валиться ошибка Segmentation fault и обрывать работу скрипта. Как выяснилось надо было вставить следующий кусочек кода, чтобы этого не происходило:

import sys
import pycurl

try:
   import signal
   from signal import SIGPIPE, SIG_IGN
   signal.signal(signal.SIGPIPE, signal.SIG_IGN)
except ImportError:
   pass

Пока не пробовал, но чтобы не забыть решил записать.

Python for SEO

Segmentation fault при использовании pycurl в Linux.

Написал клиенту простейший скрипт с использованием pycurl (я его всегда, кстати, использую), который состоит буквально из одного get-запроса, а при использовании этого скрипта под Linux, начала периодически валиться ошибка Segmentation fault и обрывать работу скрипта. Как выяснилось надо было вставить следующий кусочек кода, чтобы этого не происходило:

import sys
import pycurl

try:
   import signal
   from signal import SIGPIPE, SIG_IGN
   signal.signal(signal.SIGPIPE, signal.SIG_IGN)
except ImportError:
   pass

Пока не пробовал, но чтобы не забыть решил записать.

Блог django на хабрахабре

Django Framework / [Ссылка] Архитектура DISQUS

DISQUS — самая популярная система комментирования и самое большое в мире Django-приложение. Она установлена на полумиллионе сайтов. Особенностью в её реализации является тот факт, что DISQUS не является тем сайтом, который хотят увидеть пользователи, он лишь предоставляет механизмы комментирования, авторизации и интеграции с социальными сетями. Пики нагрузки совпадают c появлением какой-то шумихи в Интернете, что достаточно непредсказуемо. Как же им удается справляться с этой ситуацией?

Блог python на хабрахабре

Язык программирования Python / Библиотека для вывода изображений в командную строку



Fabulous — замечательная библиотека, позволяющая выводить красивый цветной текст, картинки, фигуры прямо в окно терминала!

Для того, чтобы установить библиотеку, выполните в терминале:
sudo apt-get install gcc python-imaging python-setuptools
sudo easy_install -U fabulous

Или просто скачать в архиве:

fabulous-0.1.3.tar.gz

Документация

После установки можете попробовать несколько примеров, выполнив такой код:
python -m fabulous.demo - выводит в терминал примерно первое изображение
python -m fabulous.rotating_cube
— пример вращающегося куба
python -m fabulous.image obama.jpg — после такого вызова в терминале появится следующее изображение (как видите, чтобы вывести изображение, достаточно одной строки):

Копилка опыта

Демонизация.

Шли последние часы заката. Редкие отблески багряных лучей заходящего солнца тонули в рваных клочьях густого тумана одеялом ложащегося на покосившиеся деревянные кресты… Шутка мы всё таки не будем отклоняться от тематики программирования. Несмотря на немного зловещий заголовок разговор пойдёт о вполне нормальных явлениях. Люди знакомые с операционными системами класса UNIX наверно уже догадались о чём идёт [...]

Блог python на хабрахабре

Язык программирования Python / [Ссылка] Основы применения Python в администрировании Linux

В статье описаны преимущества языка Python при использовании его в качестве инструментария для решения задач системного администрирования по сравнению с возможностями стандартного командного интерпретатора bash.

Статья, написанная Екатериной Марценюк, была опубликована 30.03.2010 на сайте ibm.com в технической библиотеке.

Блог python на хабрахабре

Язык программирования Python / Книга Gray Hat Python



Уважаемое Хабрсообщество и все интересующиеся языком программирования Python. Я начал переводить весьма интересную книгу Gray Hat Python. Правда, пока я перевел лишь предисловие и первую главу. Начал переводить для себя (поэтому немного коряво), но все таки решил, что нужно делиться. :)

И так предоставим слово автору.

Блог python на хабрахабре

Язык программирования Python / Играемся с гироскопом ноутбука thinkpad в linux

В линукс показания с этого датчика можно считать из файла /sys/devices/platform/hdaps/position
Можно создать виртуальный джойстик и, например, катать им шарики в neverball, крутить google earth и т.п. :)
Всё это описано тут
Я тоже решил развлечься и написал небольшую программу, которая заставляет cairo-clock сползать по экрану в зависимости от наклона ноутбука.

pawn hearts's weblog

Переброс окон между несколькими мониторами

В xfce я не нашел способа перекидывать окно на следующий монитор комбинацией клавиш(что-то такое я видел только в компизе), поэтому написал этот скриптик


#!/usr/bin/env python
# coding: utf-8

import wnck,sys,gobject,gtk
from gtk import gdk


def tonextmon():
    w = scr.get_active_window()
    was_max = w.is_maximized()
    was_fs = w.is_fullscreen()
    w.unmaximize()
    w.set_fullscreen(False)
    w2=gdk.window_foreign_new(w.get_xid())
    s=w2.get_screen()
    cur=s.get_monitor_at_window(w2)
    if '-p' is sys.argv:
        nxt=cur-1<0 and s.get_n_monitors()-1 or cur-1
    else:
        nxt=cur+1<s.get_n_monitors() and cur+1 or 0
    mong=s.get_monitor_geometry(nxt)
    curmong=s.get_monitor_geometry(cur)
    pos=list(w2.get_root_origin())
    pos[0]+=mong[0]-curmong[0]
    pos[1]+=mong[1]-curmong[1]
    w2.move(*pos)
    if was_max:
        w.maximize()
    w.set_fullscreen(was_fs)
    gtk.main_quit()
if __name__ == '__main__':
    scr = wnck.screen_get_default()
    gobject.idle_add(tonextmon)
    gtk.main()

Вешается на комбинацию клавиш. Ключик “-p” перекинет окно на предыдущий монитор, без ключей — на следующий

Работает с распахнутыми окнами и развернутыми на весь экран.

Скачать скрипт

pawn hearts's weblog

Играемся с гироскопом ноутбука thinkpad в linux

В линукс показания с этого датчика можно считать из файла /sys/devices/platform/hdaps/position

Можно на основе этих данных создать виртуальный джойстик и, например, катать им шарики в neverball(video), крутить google earth и т.п. :)

Почитать про это всё можно тут

Я тоже решил развлечься и написал небольшую программу, которая заставляет cairo-clock сползать по экрану в зависимости от наклона ноутбука)

Для поиска и управления окном я использовал wnck и pygtk. Чтобы сгладить движение я взял физический движок pyode.

<4:>sw-(w/2): bx=-(w/2)
    if y<-(h/2):>sh-(h/2): by=-(h/2)
    body.setPosition((bx,by,bz))
    clk.move(int(bx),int(by))
    return True

def main():
    try: 
        scr=wnck.screen_get_default()
        scr.get_windows()
        world = ode.World()
        world.setGravity( (0,0,0) )
        body = ode.Body(world)
        M = ode.Mass()
        M.setSphere(2500.0, 0.05)
        M.setBox(1000,250,250,1)
        M.mass = 0.5
        body.setMass(M)
        gobject.timeout_add(200,find_clock,scr,body,world)
        gtk.main()
    except Exception,e: 
        print(e) 
         
if __name__ == "__main__": 
    main()

Вот как это выглядит:

Ещё небольшой скриптик, который поворачивает экран если его сильно наклонить.(тот что есть на сайте ibm — не рабочий)

<-rotate_on:>ROTATE_ON: rotate('left')
        else: rotate('normal')

Метки

.net .NET C# .sort 1.2 2009 2010 404 error admin ajax amazon analytics and apache api archlinux asp.net async asynchronous autocomplete bash blender blog blogengine blogs book bootstrap bot bpython buildout byteflow bzr C c plus plus C++ cache cbv Chaco checkio chrome ci ckeditor class based views clojure closure cms cms с удобной админкой code coding style collectd COM comet competition conference ConfigParser contest Context continuous integration CouchDB coverage CppCMS cpyext cpython crud csrf CSS ctypes curl custom model fields cx_freeze cython database db dbm dbqueries debian debug debugging decorator decorators deploy deployment descriptor design dev devconf developers development diveintopython Django django 1.2 django 1.3 django advent django framework django template django trunk django weblog django-admin-tools django-cms django-compressor django-hosts django-piston django-registration django-sphinx django.admin djangoadvent djangocms djangodash doc documentation drupal e-legion eclipse EGit emacs encoding Enthought epoll erlang event exception ExtJS fabric facebook fastcgi finaloption fixtures fonts forms formset fp framework freebsd freeswitch fs2web ftp fun funcparserlib functional gae gamin gandi generic views gettext gevent gil git github gitosis Google Google App Engine google picasa Google Translate google wave Google Web Toolkit grab grablab greenlet gtd gui haskell hg hgshelve highlighter host hosting how-to howto html html5lib Hudson humor i18n icfpc ide idiomatic image-scripting improvements Internet interpreter ipython ironpython izmenimsya.ru jabber java javascript jenkins jetbrains JIT job jquery json jstree jython kde kiev kiyv kyivpy l10n ldap library libs Life Links linux Linux & Unix LLVM logging logs lxml Mac OS X magic mail markdown Matplotlib Mayavi maybe mediavirus meetup memcache Memcached memory messages metaclass middleware migration mikrotik mkd model models mod_python mod_wsgi mongodb monitoring mptt musicmans.ru musicx mvc my-projects mysql netCDF networkx newforms newforms-admin news nginx Nhibernate nix nose NoSQL numpy oop open source OpenID openoffice opster optimization oracle orm os pagination parsing path patterns pdf PDF-принтер PEP PEP8 performance performance optimization perl personality photo php picture-driven computing PIL pinax pingback pip plasma plone plugin plugins postgresql programming progress bar psycopg2 py2exe pybb pybbm pycamp pycharm pycon pycow pycurl pydev pygtk pylons PyNGL pypy pyqt PyQt4 pyrad pyramid PySide Python Python 2.5 python 2.7 python 3 python c api python speed python-mssql python3 pywinauto Qt Qt4 queue rabbitmq radius raw sql re redis redsolution redsolution cms regexp regular expressions release repoze.bfg RequestContext reusable apps robokassa rss ru ruby ruby-on-rails sample satchmo scalability SciPy scraping screencast search selenium self.error seo server setattr settings setuptools shell sikuli sms snippet socket.io software sorting south sphinx spider sql sqlalchemy sqlite ssh startup step-by-step subdomain subversion svn SyntaxHighlighter system tags tdd tddspry teh drama template templates templatetags test testing thinkpad threading threads tips tips and tricks tools tornadio tornado tornado server tricks tutorial tweepy twisted twitter typography uapycon Ubuntu ucsvlog uml Uncategorized unicode unit test unit testing UnitTest Unladen Swallow upload urllib urls utf-8 uwsgi validation vcs versioning video vim virtualenv Visual Studio vkontakte voip wave web web-devel web-services web-разработка webdev webfaction webkit webpy websockets webtest widget widgets Win API windows Wirbel work wrapper wsgi wxPython wxWidgets wysiwyg xapian xml xmonad xmpp xpath yandex youtube zip zomg zope [cdata[cbv]] [cdata[ci]] [cdata[class based views]] [cdata[continuous integration]] [cdata[django framework]] [cdata[django-sphinx]] [cdata[django]] [cdata[nginx]] [cdata[python]] [cdata[virtualenv]] [cdata[программирование]] автоматизация администрирование администрирование django админка алгоритмы архитектура атрибуты базы данных Без рубрики безопасность библиотеки блоге бот веб-разработка видео Визуализация данных вконтакте Все записи гвидо ван россум граббер графика графы декоратор декораторы дескриптор дескрипторы документация заметки игра жизнь идея интересное киев Клиентам книги конференция личное математика метаклассы модели модули монады морфология мысли невозможное новости о облачные вычисления обо мне Обработка данных оптимизация оптимизация кода Основная лента основы парсинг парсинг сайтов перевод песочница Питон поебень поиск правила кодирования программирование Проектирование производительность работа рабочее размышлизмы Разное разработка разработка приложений разработки регулярные выражения сайт событие события ссылки статьи тестирование тесты Тюмень убунтариум фигня философия формы форум Хабрахабр хакинг хостинг шаблоны шаблоны проектирования эксперимент Эксперименты юмор я пиарюсь Яндекс