dpkg-reconfigure tzdata - смена часового пояса
update-alternatives - смена дефолтного редактора
воскресенье, 18 декабря 2011 г.
суббота, 17 декабря 2011 г.
Установка svn сервера в Ubuntu
Для начала установим SVN.
Создадим репозитаий
Создадим новую группу пользователей svn и добавим в неё пользователя svn
Сменим группу владельца у репозитария
Установим доступ
Мы настроили защищенный доступ к репозитарию для людей из группы svn. Чтобы был сетевой доступ, нам необходимо запустить svnserve. Для этого создадим задачу в init.d
sudo apt-get install subversionСоздадим репозитаий
svnadmin create /var/svnСоздадим новую группу пользователей svn и добавим в неё пользователя svn
groupadd -g 56 svn && useradd -c "SVN Owner" -d /home/svn -m -g svn -s /bin/false -u 56 svnСменим группу владельца у репозитария
chown -R svn:svn /var/svnУстановим доступ
chmod -R ug+rw /var/svnМы настроили защищенный доступ к репозитарию для людей из группы svn. Чтобы был сетевой доступ, нам необходимо запустить svnserve. Для этого создадим задачу в init.d
#! /bin/sh
### BEGIN INIT INFO
# Provides: svnserve
# Required-Start: $local_fs $syslog $remote_fs
# Required-Stop: $local_fs $syslog $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start svnserve
### END INIT INFO
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="svnserve"
NAME=svnserve
DAEMON=/usr/bin/$NAME
DAEMON_ARGS="-d -r /var/svn"
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME
[ -x "$DAEMON" ] || exit 0
[ -r /etc/default/$NAME ] && . /etc/default/$NAME
. /lib/init/vars.sh
. /lib/lsb/init-functions
do_start()
{
start-stop-daemon --start --quiet --pidfile $PIDFILE --chuid svn:svn --exec $DAEMON --test > /dev/null \
|| return 1
start-stop-daemon --start --quiet --pidfile $PIDFILE --chuid svn:svn --exec $DAEMON -- \
$DAEMON_ARGS \
|| return 2
}
do_stop()
{
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
RETVAL="$?"
[ "$RETVAL" = 2 ] && return 2
start-stop-daemon --stop --quiet --oknodo --retry=0/30/KILL/5 --exec $DAEMON
[ "$?" = 2 ] && return 2
rm -f $PIDFILE
return "$RETVAL"
}
case "$1" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
restart|force-reload)
log_daemon_msg "Restarting $DESC" "$NAME"
do_stop
case "$?" in
0|1)
do_start
case "$?" in
0) log_end_msg 0 ;;
1) log_end_msg 1 ;; # Old process is still running
*) log_end_msg 1 ;; # Failed to start
esac
;;
*)
# Failed to stop
log_end_msg 1
;;
esac
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
exit 3
;;
esac
exit 0
Теперь добавляем автозагрузку при старте
update-rc.d svnserve defaults
и запускаем
sudo /etc/init.d/svnserve start
правим файлы конфиги /var/svn/conf/*
четверг, 14 июля 2011 г.
array function array_unique in postgresql
CREATE FUNCTION array_unique(anyarray)
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT id FROM (
SELECT UNNEST($1) as id
) t
GROUP BY id
ORDER BY count(*) desc
);
$FUNCTION$;
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT id FROM (
SELECT UNNEST($1) as id
) t
GROUP BY id
ORDER BY count(*) desc
);
$FUNCTION$;
array function array_size in postgresql
CREATE OR REPLACE FUNCTION array_size(anyarray)
RETURNS bigint
language sql
as $FUNCTION$
SELECT count(*) FROM (
SELECT UNNEST($1)
) t;
$FUNCTION$;
RETURNS bigint
language sql
as $FUNCTION$
SELECT count(*) FROM (
SELECT UNNEST($1)
) t;
$FUNCTION$;
среда, 13 июля 2011 г.
array function array_diff in postgresql
CREATE OR REPLACE FUNCTION array_diff(anyarray, anyarray)
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT * FROM (SELECT UNNEST($1) as element) t WHERE element not in (SELECT UNNEST($2))
);
$FUNCTION$;
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT * FROM (SELECT UNNEST($1) as element) t WHERE element not in (SELECT UNNEST($2))
);
$FUNCTION$;
array aggregate and function array_union like union all in postgresql
CREATE FUNCTION array_union(anyarray, anyarray)
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT UNNEST($1)
UNION ALL
SELECT UNNEST($2)
);
$FUNCTION$;
CREATE AGGREGATE array_union (anyarray)
(
sfunc = array_union,
stype = anyarray,
initcond = '{}'
);
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT UNNEST($1)
UNION ALL
SELECT UNNEST($2)
);
$FUNCTION$;
CREATE AGGREGATE array_union (anyarray)
(
sfunc = array_union,
stype = anyarray,
initcond = '{}'
);
array function array_intersect in postgresql
CREATE FUNCTION array_intersect(anyarray, anyarray)
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT UNNEST($1)
INTERSECT
SELECT UNNEST($2)
);
$FUNCTION$;
RETURNS anyarray
language sql
as $FUNCTION$
SELECT ARRAY(
SELECT UNNEST($1)
INTERSECT
SELECT UNNEST($2)
);
$FUNCTION$;
понедельник, 25 апреля 2011 г.
array function array_to_rows in postgresql
CREATE OR REPLACE FUNCTION array_to_rows(myarray ANYARRAY) RETURNS SETOF
ANYELEMENT AS $$
BEGIN
FOR j IN 1..ARRAY_UPPER(myarray,1) LOOP
RETURN NEXT myarray[j];
END LOOP;
RETURN;
END;
$$ LANGUAGE 'plpgsql';
ANYELEMENT AS $$
BEGIN
FOR j IN 1..ARRAY_UPPER(myarray,1) LOOP
RETURN NEXT myarray[j];
END LOOP;
RETURN;
END;
$$ LANGUAGE 'plpgsql';
вторник, 8 февраля 2011 г.
aggregate function array_agg in postgresql 8.3
CREATE AGGREGATE array_agg(anyelement) ( SFUNC=array_append, STYPE=anyarray, INITCOND='{}' );
function idx in postgresql 8.3
CREATE OR REPLACE FUNCTION idx(anyarray, anyelement) RETURNS int AS $$ SELECT i FROM ( SELECT generate_series(array_lower($1,1),array_upper($1,1)) ) g(i) WHERE $1[i] = $2 LIMIT 1; $$ LANGUAGE sql IMMUTABLE;
воскресенье, 6 февраля 2011 г.
node.js+postgresql
List of postgresql adapters for node.js:
https://github.com/ry/node_postgres
https://github.com/brianc/node-postgres - my select (the best)
https://github.com/creationix/postgres-js
https://github.com/aurynn/postgres-js
I execute command for use node-postgres:
var pg = require('pg');
var connectionString = "pg://postgres:postgres@localhost:5432/test";
pg.connect(connectionString, function(err, client) {
if (err) {
console.log('fatal error');
} else {
client.query("select version();", function(err, result) {
if (err) {
console.log('error');
} else {
console.log(result);
}
});
}
})
https://github.com/ry/node_postgres
https://github.com/brianc/node-postgres - my select (the best)
https://github.com/creationix/postgres-js
https://github.com/aurynn/postgres-js
I execute command for use node-postgres:
npm install pg example.js:var pg = require('pg');
var connectionString = "pg://postgres:postgres@localhost:5432/test";
pg.connect(connectionString, function(err, client) {
if (err) {
console.log('fatal error');
} else {
client.query("select version();", function(err, result) {
if (err) {
console.log('error');
} else {
console.log(result);
}
});
}
})
Подписаться на:
Комментарии (Atom)