Author Archives: admin - Page 14

Скорость соединения между серверами или в сети

есть такой замечтательный пакет

Iperf — кроссплатформенная консольная клиент-серверная программа — генератор TCP и UDP трафика для тестирования пропускной способности сети.

ставим его
[cc lang=”bash”]apt-get install iperf[/cc]
на тех машинах, между кем меряем.
далее, на одной запускаем сервер.

[cc lang=”bash”]iperf -s[/cc]

А на второй запускаем клиента.

[cc lang=”bash”]iperf -c 192.168.100.1 -t 300[/cc]

-t 300, как я понимаю это время 300 секунд, потом сервер вам оветит.

[cc lang=”bash”]# iperf -s
————————————————————
Server listening on TCP port 5001
TCP window size: 85.3 KByte (default)
————————————————————
[ 4] local 192.168.1.1 port 5001 connected with 10.10.10.50 port 60253
[ 4] 0.0-395.3 sec 8.45 MBytes 179 Kbits/sec
[ 6] local 211.111.111.99 port 5001 connected with 89.111.111.12 port 42926
[ 6] 0.0-300.3 sec 85.9 MBytes 2.40 Mbits/sec
[/cc]

Ubuntu NFS Server

Для обмена файлами между серверами организации мне понравилось использоваться NFSv4

Штука прикольная, но самая её радость в простоте настройке и запуске

Ставим
[cc lang=”bash”]apt-get install nfs-kernel-server nfs-common portmap[/cc]

Идём в файл
/etc/exports

А там 2 примера!
но мы посмотрим на другие

[cc lang=”bash”]/mnt/files 192.168.1.1/24(rw,no_root_squash,async)[/cc]

Каталог /mnt/files станет доступен с сети 192.168.1.1/24 на полный контроль, даже на файлы рутовские.

Или еще пример:

[cc lang=”bash”]/home/saber/ 192.168.1.12(ro,async)[/cc]
Домашний каталог сабера стал доступен по чтению только с компа 192.168.1.12

Вот и вся магия.

теперь применяем изменения
[cc lang=”bash”]/etc/init.d/nfs-kernel-server restart [/cc]

Теперь на втором компе ( где хотим примонтировать эту ФС) делаем так

[cc lang=”bash”]showmount -e 192.168.100.6[/cc]
Так мы посмотрим что есть вкусного на 192.168.100.6 машине.

[cc lang=”bash”]
Export list for 192.168.100.6:
/mnt/1500 192.168.100.1/24[/cc]

Вот нам видно, что на 6й машине есть сетевой ресурс /mnt/1500 – доступный всей сети.

смонтируем себе его (возможно понадобится пакет nfs-common если что устанавливаем)

Создадим каталок куда будем монтировать
[cc lang=”bash”]mkdir /mnt/server[/cc]

[cc lang=”bash”]mount 192.168.100.6:/mnt/1500 /mnt/server[/cc]

и всё радуемся, кидаемся файлами и папками

Хороший визуальный редактор Joomla

Этот год на сайты более горячий, чем прошлый, но хочу поделиться одним открытием, без которого мне сложно обучить красиво и быстро оформлять материалы на сайтах под управлением Jommla.

Это сторонний визуальный редактор

Умеет “искаропки” загружать файлы\картинки на сервер, линковаться уже существующие материалы и многое другое 🙂

бесплатно скачать без всяких бэкдоров и шеллов можно с Официального сайта Правда, после регистрации. Но этого стоит того! 😉

Joomla sitemap.xml

Для своевременного индексирования сайта гуглом, я использую плагин JCrawler
я перепробовал много, всяких разных, но именно этот на всех хостингах без всяких проблем создаёт файл sitemap.xml

django + twitter

“Мопед не мой, я лишь объяву разместил”
У меня пока не хватает кармы, чтоб высылать за такие статьи инвайты на хабр, поэтому видимо кроме меня этого не жалает делать никто, то буду опубликовать тут. ибо информацию считаю полезной, не только для себя.

Доброго времени суток!
Появилась необходимость следующего характера: в движке на django, при публикации новости, чтоб создавался кросс-пост на twitter. Т.е. пишем новость, жмём сохранить и на твиттере появляется пост аля «Название статьи, bit.ly/s/ссылка_на_нашу_новость».

Для реализации потребовались следующие пакеты:

1. python-oauth2 | https://github.com/simplegeo/python-oauth2
2. oauth-python-twitter2 | http://code.google.com/p/oauth-python-twitter2/
3. simplejson | http://pypi.python.org/pypi/simplejson/
4. oauth2 | http://pypi.python.org/pypi/oauth2/
5. bitlyapi | http://pypi.python.org/pypi/bitlyapi/

1-4 пакеты нужны нам для связи с twitter’ом, 5-ый для укорачивания ссылок…
Перед тем как начать предполагаю, что у Вас есть аккаунт в twitter.com и bit.ly. Если нет, то это по минуте на регистрацию на каждом из сервисов.

Начнём с twitter’a…

При-python-им twitter

Проставляем все пакеты и выполняем следующие действия (кстати они описаны выше в руководстве python-oauth2):
Логинимся в браузере в twitter.com, и после этого переходим по ссылке http://twitter.com/apps/new. Далее мы воспользуемся инструкциями из замечательной статьи:

1. Заполняем все поля на свое усмотрение, для Application Type выбираем Client
2. Для Default Access type выбираем Read & Write, Use Twitter for login я оставил не выбранным
3. Вводим капчу и сабмитим

После этого twitter сгенерит CONSUMER_KEY, CONSUMER_SECRET.
Следующие два параметра нам вернет такой скрипт

[cc lang=”python”]from oauthtwitter import OAuthApi
import pprint

CONSUMER_KEY = “*****”
CONSUMER_SECRET = “*****”

twitter = OAuthApi(consumer_key, consumer_secret)
temp_credentials = twitter.getRequestToken()
print(twitter.getAuthorizationURL(temp_credentials))
oauth_verifier = raw_input(‘What is the PIN? ‘)
access_token = twitter.getAccessToken(temp_credentials, oauth_verifier)

print(“oauth_token: ” + access_token[‘oauth_token’])
print(“oauth_token_secret: ” + access_token[‘oauth_token_secret’])

[/cc]
В CONSUMER_KEY, CONSUMER_SECRET вводим значения полученные на предыдущем этапе, запускаем. Скрипт сгенерит url, переходим по нему и копируем PIN который нам вежливо предлагает twitter. Вставляем PIN в скрипт, он как раз его ждет.

На выходе мы получим значения для двух последних параметров OAUTH_TOKEN и OAUTH_TOKEN_SECRET.
Все, теперь у нас есть все что надо для oauth авторизации, осталось немного подправить скрипты.

Готовимся сокращать ссылки вместе с bit.ly

Предельно простой и удобный модуль bitlyapi. Схема простая:

1. Регистрируемся на bit.ly
2. Логинимся
3. Переходим по ссылке
4. Копируем username и api key

Правим модель в Django

Здесь мы не рассматриваем создание модели, предполагается, что Вы это умеете. В шапку добавляем:

[cc lang=”python”]#twitter
import oauth2 as oauth
import bitlyapi
bitly = bitlyapi.BitLy(‘username bitly’, ‘api key bitly’) #вводим данные с прошлого шага
from oauthtwitter import OAuthApi
CONSUMER_KEY = “*****вводим свои данные*****”
CONSUMER_SECRET = “*****вводим свои данные*****”
OAUTH_TOKEN = “*****вводим свои данные*****”
OAUTH_TOKEN_SECRET = “*****вводим свои данные*****”
twitter = OAuthApi(CONSUMER_KEY, CONSUMER_SECRET, OAUTH_TOKEN, OAUTH_TOKEN_SECRET)

[/cc]

Переходим к моделе. Логика проста, есть boolean поле twitter_export, если галочка ставится, то новость публикуется при сохранении на твиттере. Если не понятно, то сейчас всё увидите и поймёте ))

[cc lang=”python”]class News(models.Model):
title = models.CharField(max_length=300)
content = models.TextField()
twitter_export = models.BooleanField(default=False)

def save(self):
link = bitly.shorten(longUrl=’http://example.com/news/’ + str(self.id) + ‘/’) #формируем ссылку, которая будет сокращенна
if self.twitter_export: #если стоит галочка на twitter_export
twit = u’%s… | Читать %s’ % (self.title[:70], link[‘url’]) #формируем, что писать в твиттер.. учтите, что длина сообщения в твиттере 160 символов
twitter.UpdateStatus(twit) #публикуем наш твит
self.twitter_export = False #убираем галку twitter_export
super(News, self).save()

[/cc]

Всё готово! Можно тестировать!

Источники

1. Пишем twitter-бота на python
2. Twitter Three-legged OAuth Example