백엔드 개발 파이썬 튜토리얼 슈퍼유저 액세스 없이 PostgreSQL에서 데이터베이스를 생성하고 항상 연결하는 방법

슈퍼유저 액세스 없이 PostgreSQL에서 데이터베이스를 생성하고 항상 연결하는 방법

Dec 27, 2024 am 04:48 AM

How to Create a Database and Always Connect to It in PostgreSQL Without Needing Superuser Access

이 가이드에서는 슈퍼유저가 아닌 사용자로 PostgreSQL에서 데이터베이스를 생성하고, 필요한 권한을 할당하고, 다음 작업을 수행할 수 있는지 확인하는 단계를 안내합니다. 수퍼유저로 로그인할 필요 없이 항상 새로 생성된 데이터베이스에 연결하세요.

이 기능은 모든 작업에 대해 관리 권한이 필요 없이 PostgreSQL에서 자신의 데이터베이스를 관리하려는 개발자나 사용자에게 유용합니다.

우리가 달성할 것:

1.새 데이터베이스를 생성합니다(거북이-데모).
2.수퍼유저가 아닌 역할(테스트 사용자)에게 데이터베이스를 생성하고 액세스할 수 있는 권한을 부여합니다.
3.수퍼유저로 먼저 전환할 필요 없이 원활하게 데이터베이스로 전환(tortoise-demo)합니다.
4.테스트 사용자로 로그인할 때 항상 tortoise-demo에 자동으로 연결하도록 PostgreSQL을 구성합니다.

1단계: testuser에게 필요한 권한 부여

수퍼유저가 아닌 사용자로 데이터베이스를 생성하기 전에 자신의 역할(이 경우 testuser)이 데이터베이스를 생성할 수 있는 적절한 권한을 가지고 있는지 확인해야 합니다.

CREATEDB 권한 부여

기본적으로 새로 생성된 PostgreSQL 역할에는 데이터베이스를 생성할 수 있는 권한이 없습니다. 슈퍼유저(예: postgres)로 로그인한 경우 테스트유저 역할에 필요한 권한을 부여할 수 있습니다.

1.슈퍼유저로 로그인(예: postgres):

   psql -U postgres
로그인 후 복사
로그인 후 복사

2.테스트 사용자에게 CREATEDB 권한 부여:

테스트 사용자가 새 데이터베이스를 생성할 수 있도록 다음 SQL 쿼리를 실행하세요.

   GRANT CREATEDB TO "testuser";
로그인 후 복사
로그인 후 복사

이렇게 하면 테스트 사용자가 슈퍼유저 권한 없이도 데이터베이스를 생성할 수 있습니다.

3.수퍼유저 세션 종료:

   \q
로그인 후 복사
로그인 후 복사

2단계: testuser로 로그인하고 데이터베이스 생성

이제 testuser 역할에 CREATEDB 권한이 있으므로 testuser로 로그인하여 새 데이터베이스를 생성할 수 있습니다.

테스트 사용자로 로그인:

testuser 역할로 로그인하려면 다음 명령을 실행하세요.

psql -U "testuser" -d postgres -W
로그인 후 복사
로그인 후 복사
  • -U "testuser" 옵션은 사용자를 지정합니다.
  • -d postgres 옵션은 postgres 데이터베이스(기본 관리 데이터베이스)에 연결합니다.
  • -W 옵션은 testuser에 대해 설정한 비밀번호(예: 1234567890)를 묻는 메시지를 표시합니다.

거북이 데모 데이터베이스를 생성합니다:

로그인한 후 새 데이터베이스 tortoise-demo를 만듭니다.

CREATE DATABASE "tortoise-demo";
로그인 후 복사
로그인 후 복사

이 명령은 tortoise-demo라는 새 데이터베이스를 생성합니다.

소유권 설정(선택 사항):

testuser가 데이터베이스에 대한 모든 권한을 갖도록 하려면 데이터베이스 소유권을 testuser에게 할당할 수 있습니다.

   psql -U postgres
로그인 후 복사
로그인 후 복사

이 단계는 선택 사항이지만 testuser 역할이 tortoise-demo 데이터베이스에 대한 전체 관리 제어 권한을 갖도록 보장합니다.

3단계: tortoise-demo 데이터베이스로 전환

데이터베이스를 생성한 후 새로 생성된 데이터베이스로 전환(거북이 데모)하여 작업을 시작할 수 있습니다.

Tortoise-demo에 연결하려면 다음을 실행하세요.

   GRANT CREATEDB TO "testuser";
로그인 후 복사
로그인 후 복사

c 명령은 현재 세션을 tortoise-demo 데이터베이스로 전환합니다. 이제부터 SQL 쿼리를 실행하고 데이터베이스를 관리할 수 있습니다.

4단계: 매번 전환할 필요 없이 tortoise-demo 연결 자동화

이제 tortoise-demo 데이터베이스를 성공적으로 생성하고 전환했으므로 다음 단계는 이 프로세스를 자동화하는 것입니다. 특히, 우리는 folasayoolayemi로 로그인할 때마다 명시적으로 전환할 필요 없이 자동으로 tortoise-demo 데이터베이스에 연결되도록 PostgreSQL을 구성하려고 합니다.

옵션 1: PGDATABASE 환경 변수 설정

항상 tortoise-demo 데이터베이스에 연결되도록 하는 쉬운 방법 중 하나는 PGDATABASE 환경 변수를 설정하는 것입니다. 이 변수는 연결 시 기본적으로 사용할 데이터베이스를 PostgreSQL에 알려줍니다.

1.현재 세션에 대한 PGDATABASE 설정:

현재 터미널 세션에서 다음과 같이 환경 변수를 설정할 수 있습니다.

   \q
로그인 후 복사
로그인 후 복사

이렇게 하면 이후에 실행하는 모든 psql 명령이 기본적으로 tortoise-demo에 자동으로 연결됩니다.

2.변경 사항을 영구적으로 적용:

이 변경 사항이 터미널 세션 전반에 걸쳐 지속되도록 하려면 셸의 구성 파일(.bashrc, .zshrc 등)에 내보내기 명령을 추가하세요.

예를 들어 bash를 사용하는 경우 ~/.bashrc 파일에 다음 줄을 추가하세요.

psql -U "testuser" -d postgres -W
로그인 후 복사
로그인 후 복사

그런 다음 다음을 실행하세요.

CREATE DATABASE "tortoise-demo";
로그인 후 복사
로그인 후 복사

이렇게 하면 새 터미널 세션을 열 때마다 PostgreSQL이 데이터베이스를 지정할 필요 없이 자동으로 tortoise-demo에 연결됩니다.

옵션 2: 연결 명령에 항상 데이터베이스 지정

PGDATABASE 환경 변수를 사용하지 않으려면 언제든지 psql 연결 명령에 데이터베이스 이름을 지정할 수 있습니다.

ALTER DATABASE "tortoise-demo" OWNER TO "testuser";
로그인 후 복사

이렇게 하면 연결할 때마다 tortoise-demo 데이터베이스를 직접 지정하므로 구성을 변경할 필요가 없습니다.

주요 단계:

1.CREATEDB 권한 부여: testuser 역할에 데이터베이스를 생성하는 데 필요한 권한이 있는지 확인하세요.
2.데이터베이스 생성: testuser로 로그인하고 tortoise-demo 데이터베이스를 생성합니다.
3.데이터베이스로 전환: tortoise-demo로 전환하려면 c 명령을 사용하세요.
4.데이터베이스 연결 자동화: 기본적으로 항상 tortoise-demo에 연결하도록 PGDATABASE 환경 변수를 설정하거나 psql 명령에 데이터베이스 이름을 명시적으로 지정합니다.

결론:

이 단계를 수행하면 새 데이터베이스를 생성해야 할 때마다 슈퍼유저 권한이 필요하지 않고 슈퍼유저가 아닌 사용자로서 PostgreSQL에서 자체 데이터베이스를 생성하고 관리할 수 있습니다. 특정 데이터베이스에 자동으로 연결하는 기능은 특히 특정 프로젝트나 애플리케이션을 사용하는 개발자의 작업 흐름을 더욱 효율적으로 만들어줍니다.

읽어주셔서 감사합니다...
즐거운 코딩하세요!

위 내용은 슈퍼유저 액세스 없이 PostgreSQL에서 데이터베이스를 생성하고 항상 연결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Python vs. C : 학습 곡선 및 사용 편의성 Python vs. C : 학습 곡선 및 사용 편의성 Apr 19, 2025 am 12:20 AM

Python은 배우고 사용하기 쉽고 C는 더 강력하지만 복잡합니다. 1. Python Syntax는 간결하며 초보자에게 적합합니다. 동적 타이핑 및 자동 메모리 관리를 사용하면 사용하기 쉽지만 런타임 오류가 발생할 수 있습니다. 2.C는 고성능 응용 프로그램에 적합한 저수준 제어 및 고급 기능을 제공하지만 학습 임계 값이 높고 수동 메모리 및 유형 안전 관리가 필요합니다.

파이썬과 시간 : 공부 시간을 최대한 활용 파이썬과 시간 : 공부 시간을 최대한 활용 Apr 14, 2025 am 12:02 AM

제한된 시간에 Python 학습 효율을 극대화하려면 Python의 DateTime, Time 및 Schedule 모듈을 사용할 수 있습니다. 1. DateTime 모듈은 학습 시간을 기록하고 계획하는 데 사용됩니다. 2. 시간 모듈은 학습과 휴식 시간을 설정하는 데 도움이됩니다. 3. 일정 모듈은 주간 학습 작업을 자동으로 배열합니다.

Python vs. C : 성능과 효율성 탐색 Python vs. C : 성능과 효율성 탐색 Apr 18, 2025 am 12:20 AM

Python은 개발 효율에서 C보다 낫지 만 C는 실행 성능이 높습니다. 1. Python의 간결한 구문 및 풍부한 라이브러리는 개발 효율성을 향상시킵니다. 2.C의 컴파일 유형 특성 및 하드웨어 제어는 실행 성능을 향상시킵니다. 선택할 때는 프로젝트 요구에 따라 개발 속도 및 실행 효율성을 평가해야합니다.

Python vs. C : 주요 차이점 이해 Python vs. C : 주요 차이점 이해 Apr 21, 2025 am 12:18 AM

Python과 C는 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1) Python은 간결한 구문 및 동적 타이핑으로 인해 빠른 개발 및 데이터 처리에 적합합니다. 2) C는 정적 타이핑 및 수동 메모리 관리로 인해 고성능 및 시스템 프로그래밍에 적합합니다.

Python 학습 : 2 시간의 일일 연구가 충분합니까? Python 학습 : 2 시간의 일일 연구가 충분합니까? Apr 18, 2025 am 12:22 AM

하루에 2 시간 동안 파이썬을 배우는 것으로 충분합니까? 목표와 학습 방법에 따라 다릅니다. 1) 명확한 학습 계획을 개발, 2) 적절한 학습 자원 및 방법을 선택하고 3) 실습 연습 및 검토 및 통합 연습 및 검토 및 통합,이 기간 동안 Python의 기본 지식과 고급 기능을 점차적으로 마스터 할 수 있습니다.

Python Standard Library의 일부는 무엇입니까? 목록 또는 배열은 무엇입니까? Python Standard Library의 일부는 무엇입니까? 목록 또는 배열은 무엇입니까? Apr 27, 2025 am 12:03 AM

Pythonlistsarepartoftsandardlardlibrary, whileraysarenot.listsarebuilt-in, 다재다능하고, 수집 할 수있는 반면, arraysarreprovidedByTearRaymoduledlesscommonlyusedDuetolimitedFunctionality.

파이썬 : 자동화, 스크립팅 및 작업 관리 파이썬 : 자동화, 스크립팅 및 작업 관리 Apr 16, 2025 am 12:14 AM

파이썬은 자동화, 스크립팅 및 작업 관리가 탁월합니다. 1) 자동화 : 파일 백업은 OS 및 Shutil과 같은 표준 라이브러리를 통해 실현됩니다. 2) 스크립트 쓰기 : PSUTIL 라이브러리를 사용하여 시스템 리소스를 모니터링합니다. 3) 작업 관리 : 일정 라이브러리를 사용하여 작업을 예약하십시오. Python의 사용 편의성과 풍부한 라이브러리 지원으로 인해 이러한 영역에서 선호하는 도구가됩니다.

웹 개발을위한 파이썬 : 주요 응용 프로그램 웹 개발을위한 파이썬 : 주요 응용 프로그램 Apr 18, 2025 am 12:20 AM

웹 개발에서 Python의 주요 응용 프로그램에는 Django 및 Flask 프레임 워크 사용, API 개발, 데이터 분석 및 시각화, 머신 러닝 및 AI 및 성능 최적화가 포함됩니다. 1. Django 및 Flask 프레임 워크 : Django는 복잡한 응용 분야의 빠른 개발에 적합하며 플라스크는 소형 또는 고도로 맞춤형 프로젝트에 적합합니다. 2. API 개발 : Flask 또는 DjangorestFramework를 사용하여 RESTFULAPI를 구축하십시오. 3. 데이터 분석 및 시각화 : Python을 사용하여 데이터를 처리하고 웹 인터페이스를 통해 표시합니다. 4. 머신 러닝 및 AI : 파이썬은 지능형 웹 애플리케이션을 구축하는 데 사용됩니다. 5. 성능 최적화 : 비동기 프로그래밍, 캐싱 및 코드를 통해 최적화

See all articles