вторник, 31 июля 2012 г.

git



**** update in dev *****

git stash save
git checkout master
git pull
git checkout dev
git stash pop
***************

insufficient permission

При следующих ошибках:
  • bash-3.2$ git commit -am 'foo' error: insufficient permission for adding an object to repository database .git/objects error: Error building trees
  • error: insufficient permission for adding an object to repository database ./objects fatal: failed to write object error: unpack failed: unpack-objects abnormal exit
нужно сделать:
1. simple permissions error (sudo chown hatim:hatim .git -R fixed it)
2. ssh to server
cd repository.git sudo chmod -R g+ws * sudo chgrp -R mygroup * git repo-config core.sharedRepository true and the try to push origin master again
Если не помогло:

Как вариант можно пересоздать связь с удаленным репозиторием:
git remote rm origin - удаляем старую связь
git remote add origin git@server:repo.git - создаем новую связь

суббота, 28 июля 2012 г.

Java script библиотеки генерации графиков и диаграмм (amCharts, Highcharts, Raphaeljs, ...)

 У меня была задача выбрать java script библиотеку для генерации графиков и диаграмм в любом браузере и на любой операционной системе, в том числе iOS.

Существуют решения, позволяющие в браузерах использовать SVG для визуализации графики, а в Internet Explorer рисовать с помощью VML.

Сравнительные характеристики

amCharts
Highcharts
http://www.highcharts.com/stock/demo/
Google Chart
Raphaeljs
http://raphaeljs.com/analytics.html
Flot jQuery
Elycharts
http://elycharts.com/examples
ОС, браузеры IE  6.0 +
Firefox
Chrome
Safari
 Opera
iOS (iPad, iPhone, iPod Touch)
Android Honeycomb
IE  6.0 +
Firefox 2.0 +
Chrome 1.0 +
Safari 4.0 +
Opera 9.0 +
iOS (Safari)3.0 +
Android Browser2.0 +
Older IE
iPhones, iPads (баги)
Android
and other
IE  6.0+
Firefox 3.0+
Chrome 5.0+
 Safari 3.0+
Opera 9.5+
iOS (Safari)
Android Browser
IE  6.0+
Firefox 2.x+
Safari 3.0+
Opera 9.5+ Konqueror 4.x+
iOS
IE  6.0+
Firefox 3.0+
Chrome
 Safari 3.0+
Opera 9.5+
frameworks + + + +
Совмещение диаграмм + только          
JavaScript Charts
Только highcharts + +
Масштабирование по х, у + только          
JavaScript Charts
Только highcharts +/? ?
Вывод точек с описанием + + + +
Разбиение по временным отрезкам + + - - -
Использует js frameworks - Опционально:  jQuery, Mootools , Prototype - jQuery jQuery jQuery
Импорт данных JS, CSV, XML JS,  опционально: JSON , CSV, XML JS,  JSON , Chart Tools Datasource protocol, JSON , CSV, XML, … JS,  теоретически: JSON , CSV, XML JS JS,  теоретически: JSON , CSV, XML
Клиенты Microsoft, Cisco, NASA, Motorola, Siemens Yandex,  IBM, NASA, Siemens, EMC, Sony Весь мир ? ?
Стоимость 61 500 р.
Charts – 22 500 р
23 000 -  130 000 р.
Highcharts – 12 600 – 60 000 р
free free free free
Лицензия + OEM license
http://shop.highsoft.com/highstock.html#faq
API Google
https://developers.google.com/terms/
Licensed under the MIT http://raphaeljs.com/license.html - MIT
Особенности Изменение графиков в реальном времени Вариант генерации на стороне клиента с помощью JSили на стороне Google и возврат картинки. Изменение графиков в реальном времени
Впечатление Большая функциональность. В iOSпроблемы у справлением скролов Проработанный, развивающийся корпоративный продукт. Но есть баги с прорисовкой в IE 6. Быстро работает. Очень много документации. Настораживает переменчивость в политике Google Поддерживается одним разработчиком Можно использовать для вывода без разбиения по периодам Сомнительный

Функционал

amCharts
Highcharts
amCharts
Highstock
amCharts
сводная
Highcharts
сводная
Highcharts
JavaScript Charts
Highcharts
JavaScript Stock Chart
Линия с кнопками временных периодов
-
+
+
+
-
+
Линия со строкой  временного периода
+
+
+
+
+
+
Несколько линейных графиков с выводом инф в одном всплывающем окне
+
-
+
+
+
+
Диаграмма пирог
+
-
+
+
+
-
Диаграмма 3Д пирог
+
-
+
-
-
-
Диаграмма столбцы вертикальные / горизонтальные
+
-?
+
+
+
+/-
Диаграмма пирог и столбец с углублением
-
-
-
-/+
-/+
-
Совмещение диаграмм
+
-?
+
+
+
-
Масштабирование по х, у
+
-
+
+
+
+
Вывод произвольных точек с описанием
+
+
+
+
+
+?
Диаграмма пузырьками
+
-
+
-
-
-

Скорость генерации графика

Браузер
amCharts
line (ms)
amCharts
column (ms)
Highcharts
line (ms)
Highcharts
column (ms)
firefox 438.537, 91553 вызовов 101.633, 4398 вызовов 1.27, 47 вызовов 222.974, 30136 вызовов
chrome 349 78 1 131
IE9 2539 640 1 5
IE8 1689 415 1 286
IE7 194059 330 10 630
IE6 235298 431 10 631
Opera 12 1785 472 1 550
Opera 11 3000 90 1 61
Android 4370 113 7 53
iOS 5212 188 16 553

пятница, 13 июля 2012 г.

Прототипирование интерфейсов

create wireframes, mockups or UI concepts, prototypes depending
Как то мне понадобилось подобрать сервис для легкого создание макета интерфейса сайта для использования в техническом задании. Одним из критериев была работа во всех браузерах. Выбирал среди следующих:

Создаем счетчик для размещения на других сайтах

Создаем счетчик для размещения на других сайтах


На странице пользователя:

<script src="//domain/gc.js" type="text/javascript"></script>
<script type="text/javascript">
    try { var gluCounter11111111111 = new Glu.Counter(11111111111); } catch(e){}
</script>
<noscript>
    <a href="http://domain/click/11111111111" target="_blank">
        <img src="//domain/counters/11111111111.png" alt="" />
    </a>
</noscript>

Тег <script type="text/javascript"> используется дважды для того что бы инициализация класса во втором теге произошла только после того как подгрузится файл с удаленного сервера.

Содержимое файла gc.js:

document.write("<a href='http://domain/click' target='_blank'><img src='http://domain/counters/11111111111.png?"+Math.random()+"' alt='' /><\/a>")


Пивот (PIVOT) – это разворот таблицы


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

Описание принципа здесь http://easy4web.ru/?p=1099

По сути мы столбцы переносим в колонки.
В чем задача? Она схожа с обсуждаемым недавно здесь вопросом http://sqlinfo.ru/forum/viewtopic.php?id=4252 + небольшое отличие
Есть упрощенно такая структура таблиц (каталог товаров, с делением по характеристикам):

CREATE TABLE categories (category_id, ... );
CREATE TABLE products (product_id, category_id,...);
CREATE TABLE properties (property_id, ...);
CREATE TABLE products2properties  (category_id, property_id);
CREATE TABLE properties_values (product_id, property_id, value);
 
products2properties   - моя таблица. Нужна потому что товары из разных категории имеют разный набор характеристик на всю категорию.

Необходимо вывести первые 10 товаров с их характеристиками + сортировка и поиск по любой характеристики.

Решение SELECT .. SELECT ...SELECT конечно же не приемлемо. Решать это средствами PHP накладно.

Давайте вместе подумаем как сделать оптимально!

Решение 1:
http://stackoverflow.com/questions/6498 … lue-schema
Средствами PHP собираем запрос из кучи JOIN.
Я думаю сервер от такого рухнит.

Решение 2:
что то умное предлагаю здесь но я не понимаю сленга)
http://bb.ct.kz/topic/189790-sql-vivest … p__7088923
Цитата того что понимаю:
Если столбцов количество неизвестно то только динамик скул...
Приблизительный алгоритм...
1. Получаем параметры...
2. Создаем запрос...
3. тут можно или представление создать или временную таблицу...
4. если временная таблица... заполняем данными...
5. с клиента пишем select * from vwView(ttTable)

Как вариант... тот же самый пайвотинг инсерт...
Решение 3:
То которое я сейчас рассматриваю...
http://www.orafaq.com/forum/m/30557/684 … #msg_30557
Проблема что оно вроде для ОРАКЛа т.к. у  меня выдает ошибку на название команд.

SQL> CREATE OR REPLACE PACKAGE pkg
  2  IS
  3      TYPE t_rc IS REF CURSOR;
  4  END pkg;
  5  /

Package created.

SQL> CREATE OR REPLACE PROCEDURE dynamic_pivot (rc IN OUT pkg.t_rc)
  2  IS
  3      l_count     NUMBER;
  4      l_sql       VARCHAR2(32000);
  5  BEGIN
  6      SELECT   MAX(COUNT(*))
  7      INTO     l_count
  8      FROM     b
  9      GROUP BY b.id;
 10
 11      l_sql := 'SELECT x.id, x.a_name';
 12
 13      FOR i IN 1..l_count LOOP
 14          l_sql := l_sql
 15                   || ',MAX(DECODE(x.rn,'
 16                   || TO_CHAR(i)
 17                   || ',x.b_value)) val'
 18                   || TO_CHAR(i);
 19      END LOOP;
 20      l_sql := l_sql
 21               || ' FROM (SELECT a.id, a.name a_name'
 22               || ',b.value b_value'
 23               || ',ROW_NUMBER() OVER (PARTITION BY a.id ORDER BY NULL) rn'
 24               || ' FROM a, b WHERE a.id = b.id) x GROUP BY x.id, x.a_name'
 25               || ' ORDER BY x.id';
 26      OPEN rc FOR l_sql;
 27  END dynamic_pivot;
 28  /

Procedure created.

SQL> VARIABLE my_rc REFCURSOR
SQL> EXEC dynamic_pivot(:my_rc);

PL/SQL procedure successfully completed.

SQL> PRINT :my_rc

        ID A_NAM VAL1  VAL2  VAL3  VAL4  VAL5  VAL6  VAL7
---------- ----- ----- ----- ----- ----- ----- ----- -----
       100 test  val1  val2
       101 hello aloha hi    wave  smile hey   hola  g'day



Временный итог:
Думаю может сделать процедуру для Мускула как в решении 3. Повесить триггер на изменение таблиц товаров что бы дергал эту процедуру пересчета (в идеале только того товара/категории которая изменилась). Процедура будет создавать таблицу Х удобную для простой выборки.

Ваше мнение? Как это всё написать? Я ни триггеры ни процедуры ни разу не писал....


Информация по теме:
http://ru.w3support.net/index.php?db=so&id=778079
http://www.sql.ru/faq/faq_topic.aspx?fid=210
http://forums.mysql.com/read.php?98,7000,7000
http://dev.mysql.com/tech-resources/art … rsion.html
http://en.wikibooks.org/wiki/MySQL/Pivot_table

Сравнение цен на Виртуальный хостинг и VPS

Сравнение цен на Виртуальный хостинг (shared hosting) и VPS

Приведены Российские и международные компании

Сравнение ведется: ЦЕНА / КОЛИЧЕСТВО САЙТОВ (доменов) /  КОЛИЧЕСТВО БАЗ ДАННЫХ / ОБЪЕМ ЖЕСТКОГО ДИСКА
иногда ПРОЦЕССОР / ОПЕРАТИВНАЯ ПАМЯТЬ / ПОДДЕРЖКА Memcache
masterhost.ru Тариф «Образовательный» Эффективный Специалист
0р 1д/1бд/Мб.500 300р 10/5/1500 575 15/10/3
sweb SX-2 SX-4 SEO64.SW SEO128.SW VDS
Memcache+(без тех помощи) 120 4/4/2 200 8/8/4 200 64/65/128м 450 128/129/512 425 рHDD(Gb) 5/RAM(Mb) 256/CPU(Mhz) 400
nic.ru 201 301
260 6/99(1пользов)/2 410 12/99/3
r01.ru Старт+ Стандарт Мастер Бизнес
85 1/1/100 Мб 185 3/10/2 275 6/20/4 460 12/99/8
reg.ru 1 2 3
249 10/10/2 349 20/20/4 499 30/30/6
ruweb.net ** VDS'8-MINI
Memcache+
Подд350р-1ч
50 1/10/100мб 520р(468р/442р) 6Гб 768/256Мб 250МГц
jino.ru *** ***
117 3/3/3 177-193 10/3-10/3
valuehost.ru План Я План A2.0 План Б2.0 План В2.0 Колокейшн 1U
Memcache+ 108 99/1/1 340 99/15/25 680 99/30/50 1020 99/50/75 2275 р
hostgator.com Hatchling Baby Business
205р 1/99/99 300р 99/99/99 440 99/99/99
godaddy.com economy plan (только одна папка) deluxe plan  unlimited+plan
160 99_25/10/10 224р 99/25/150г 465 99/99/99
000webhost.com Free
0 5/2/1500
agava Normal SEO
207р 4д/5бд/Мб.2000 350р 64д/64д/Мб.256
infobox.ru Econom
Memcache- 225 10/10/2000
dreamhost.com What's Included Vps (memcache+)
270р 999/999/999 450р

io-hosts.ru IO-VZ30
http://hosting101.ru/io-hosts.ru
PP10
10 Мб/с
500 CPU, MHz 384 RAM, МБ10 HDD, ГБ
689 р/мес
.msk.ru .spb.ru 180(150) / 120
.ru230(200) / 170
truevds.ru True20 True21
480 CPU MHz, RAM 256 Mb, HDD 8 Gb
640 р/мес
720 CPU MHz, RAM 384 Mb, HDD 12 Gb
920 р/мес
agava Optimal Basic
1000 CPU, MHz 512 RAM, МБ12 HDD, ГБ
1 249р/мес + 75
500 CPU, MHz 256 RAM, МБ6 HDD, ГБ
700  р/мес + 100
http://masterhost.ru/service/hosting/vps/unix/
500 CPU, MHz 768 RAM, МБ5 HDD, ГБ
1150р/мес
spb.hc.ruклиенты VPS1
оверселлинг по оперативной памяти
-PP
600 CPU, MHz 512 RAM, МБ5 HDD, ГБ
700р/мес
majordomo.ru VS1
http://hosting101.ru/majordomo.ru-vps 600 CPU, MHz 288 RAM, МБ10 HDD, ГБ
800р/мес
sweb VX-1 VX-2
400 CPU, MHz 256 RAM, МБ5 HDD, ГБ
490р/месс-Панели управления
800 CPU, MHz 512 RAM, МБ10 HDD, ГБ
970р/месс-Панели управления
firstvds.ru
http://hosting101.ru/firstvds.ru
VDS-Отрыв Ru - 150
PP10
Начинающих экспериментаторов
500 CPU, MHz256 RAM, МБ 6 HDD, ГБ
400р/мес
ispserver.com VDS A
PP10
Отзывы ну так
600 CPU, MHz 512 RAM, МБ5 HDD, ГБ
700р/мес
selectel.ru VDS-512
10 Mbit/sec новые CPU - 512MHz, RAM - 512MB, HDD - 51,2GB 512 руб./мес.

данные на сентябрь 2010

Сравнение цен на регистрацию и продление доменов в зоне RU и NET

 Сравнение цен на регистрацию и продление доменов в зоне RU и NET


доменная зона
регистрация, руб./год / продление, руб./год
site
.ru
net
agava 150/450 450/450
masterhost.ru 196/196 784/784
sweb 370/370 450/450
nic.ru 600/150 620/620
webnames.ru 390/390 390/390
r01.ru 590/415 440/440
reg.ru 590/590 450/450
ruweb.net 300-370/300-370 390/390
jino.ru 590 /413 369/369
valuehost.ru 195 295 
hostgator.com 440
godaddy.com 263
domains.webmoney.ru 110 390
dreamhost.com - 300
infobox.ru 600/450 490

ruweb.net valuehost.ru nic.ru io-hosts.ru Masterhost agava
.msk.ru 190/150 230  225 180(150) / 120 480 150
.spb.ru 190/150 230 450 180(150) / 120 480 350

данные на сентябрь 2010

mod_auth для входа по паролю

установка mod_auth или mod_auth_mysql для входа по паролю без использования .htaccess


если вам надоело:

AuthType Basic
AuthName "only members"
AuthUserFile /var/www/valid-user.passwd
Require valid-user

сервисы для сбора отзывов и идей от клиентов


сервис впечатление
бесплатный доступ


userecho.com на русском
  • Интеграция с Twitter
  • Интеграция с Facebook
  • Интеграция с Вконтакте
  • Интеграция с Google+
+ Блок Форумов
+ Jira
userreport.com
  • англ. язык
  • простая
reformal.ruпростой в настройке без временных ограничений с урезанным функционалом Можно авторизоваться через VK, Facebook, Google, Twitter, Mail.ru, Yandex и социальную сеть Одноклассники
copiny.com сложный функционал
Вывод информации о группе Вконтакте и сообщений из Twitter
без временных ограничений с урезанным функционалом.
Представителей компании до 3.
  • Интеграция с Twitter
  • Интеграция с Facebook
  • Интеграция с Вконтакте
Можно авторизоваться через VK, Facebook, Google, Twitter, Mail.ru, Yandex.
opinionlab.com
  • англ. язык
  • мощная но отстала от времени по юзабилити
getsatisfaction.com англ. язык
мощная система. 
только на месяц интеграция с соц. сетями и CRM системами (Jira,....)
uservoice.com англ. язык только на месяц