dpkg-reconfigure tzdata - смена часового пояса
update-alternatives - смена дефолтного редактора
Goncharov Vladimir Igorevich
воскресенье, 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$;
Подписаться на:
Комментарии (Atom)