{"id":165,"date":"2003-09-09T23:29:00","date_gmt":"2003-09-09T23:29:00","guid":{"rendered":"http:\/\/ellery.no-ip.info\/wp\/thinkingmore\/2003\/09\/09\/firebird-on-linux\/"},"modified":"2003-09-09T23:29:00","modified_gmt":"2003-09-09T23:29:00","slug":"firebird-on-linux","status":"publish","type":"post","link":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/2003\/09\/firebird-on-linux\/","title":{"rendered":"Firebird on Linux"},"content":{"rendered":"<p>\u7248\u672c\u8207\u74b0\u5883<br \/>\n==========<br \/>\nFirebird: 1.0<br \/>\nOS: Red Hat Linux 9.0<br \/>\n\u5b89\u88dd<br \/>\n====<br \/>\n\u8acb\u5148\u9023\u7d50\u5230 http:\/\/sourceforge.net\/project\/showfiles.php?group_id=9028 \u9019\u500b\u7db2\u5740<br \/>\n\u6e96\u5099\u4e0b\u8f09 RPM(For Red Hat, SuSE, Mandrake) \u6216 tarball(For any distribuation) \u5305.<br \/>\n\u9019\u88e1\u4f60\u6703\u770b\u5230\u6709\u5169\u500b\u6a94\u6848<br \/>\n\u4e00\u500b\u662f FirebirdCS-x.y.z.nnnn-xx.ixxx.rpm<br \/>\n\u4e00\u500b\u5247\u662f FirebirdSS-x.y.z.nnnn-xx.ixxx.rpm<br \/>\n\u9019\u5169\u500b\u6709\u4ec0\u9ebc\u5dee\u5225\u5462??<br \/>\n\u6240\u8b02\u7684 CS \u5c31\u662f Classic, \u8f03\u50b3\u7d71\u7684,\u4e4b\u524d,Firebird \u90fd\u662f\u639b\u5728 inetd, xinetd \u4e0b,\u505a\u70ba\u7db2\u8def\u670d\u52d9\u7684<br \/>\n\u4e5f\u5c31\u662f inetd \/ xinetd \u8ca0\u8cac\u50be\u807d\u7db2\u8def\u662f\u5426\u6709\u9700\u6c42,\u6709\u9700\u6c42,\u518d\u628a Firebird \u53eb\u8d77\u4f86,\u5c07\u9700\u6c42\u8f49\u4ea4\u7d66 Firebird.<br \/>\nSS \u5247\u662f SuperServer, \u555f\u52d5\u6642\u5c31\u662f\u7368\u7acb\u8d77\u4f86\u50be\u807d\u7db2\u8def\u9700\u6c42,\u5982\u679c\u6709\u9700\u6c42,\u81ea\u5df1\u5c31\u51fa\u4f86\u670d\u52d9\u9019\u500b\u9700\u6c42.<br \/>\n\u5728\u5b98\u65b9\u7db2\u7ad9\u88e1\u9762\u6709\u5c0d\u6b64\u4f5c\u8a73\u7d30\u7684\u6bd4\u8f03\u8207\u8aaa\u660e.http:\/\/www.ibphoenix.com\/main.nfs?a=ibphoenix&amp;page=ibp_ss_vs_classic<br \/>\n\u4f9d\u64da\u6b64\u6587\u4ef6,\u5b83\u662f\u8aaa SuperServer \u6548\u7387\u8f03\u597d.<br \/>\n\u5728\u9019\u88e1\u6211\u9078\u64c7\u4e86 CS \u7248\u672c\u7684 RPM \u4f86\u5b89\u88dd.\u539f\u56e0\u6211\u6703\u5728&#8221;\u5b89\u5168\u6027\u8b70\u984c&#8221;\u4e00\u7bc0\u518d\u8aaa\u660e.<br \/>\n\u63a5\u4e0b\u4f86\u5c31\u662f\u5b89\u88dd\u5566.<br \/>\nRPM \u7248\u672c\u5c31\u7528 rpm -ivh FirebirdCS-x.y.z.nnnn-xx.ixxx.rpm<br \/>\ntarball \u7248\u672c\u5c31\u5148\u7528 tar xzf Firebird-x.y.z.nnnn.src.tar.gz \u89e3\u958b,\u9032\u5165\u8a72\u76ee\u9304\u5f8c,\u518d\u57f7\u884c .\/install.sh \u5373\u53ef<br \/>\n\u5982\u679c\u4f60\u662f\u7528 RPM \u5b89\u88dd\u7684\u8a71,\u5b89\u88dd\u4ee5\u5f8c\u7684\u6a94\u6848\u90fd\u6703\u653e\u5728 \/opt\/interbase \u4e0b.<br \/>\n\u7ba1\u7406<br \/>\n====<br \/>\n\u7ba1\u7406\u4e0a,\u4f60\u53ef\u4ee5\u5f9e\u9060\u7aef\u7528 GUI \u7684\u7ba1\u7406\u4ecb\u9762\u4f86\u7ba1\u7406.<br \/>\n\u4e5f\u53ef\u4ee5\u4f7f\u7528 Firebird \u5167\u9644\u7684 isql, gsec \u4f86\u7ba1\u7406.<br \/>\ngsec \u4e3b\u8981\u7528\u4f86\u8b8a\u66f4\u555f\u52d5\u5bc6\u78bc\u4ee5\u53ca\u589e\u52a0\u4f7f\u7528\u8005\u7b49\u7b49\u7684,\u9664\u6b64\u4e4b\u5916,<br \/>\nFirebird \u6709\u63d0\u4f9b\u4e00\u500b\u4e0d\u932f\u7684 script \u4f86\u5e6b\u52a9\u4f60\u8b8a\u66f4\u555f\u52d5\u5bc6\u78bc.<br \/>\n\u6307\u4ee4\u540d\u7a31\u662f: \/opt\/interbase\/bin\/changeDBAPassword.sh<br \/>\n\u53ea\u8981\u4f9d\u7167\u6307\u793a\u5373\u53ef,\u4f46\u6709\u6642\u6703\u5931\u6557,\u9700\u8981\u624b\u52d5\u4fee\u6539,\u9019\u6642\u5019\u5c31\u8981\u7528\u5230 gsec,\u6b65\u9a5f:<br \/>\n1. \/opt\/interbase\/bin\/gsec<br \/>\n2. &gt; modify SYSDBA -pw your_password<br \/>\n3. &gt; quit<br \/>\n4. \u5982\u679c\u662f\u7528 SS \u5b89\u88dd\u7684\u8a71,\u90a3\u9ebc\u4f60\u5f97\u8981\u4fee\u6539 \/etc\/init.d\/firebird, \u627e\u5230 ISC_PASSWORD, \u4fee\u6b63\u4e4b;\u7528 CS \u7684\u8a71,\u8acb\u8df3\u5230\u4e0b\u500b\u6b65\u9a5f<br \/>\n5. \u4fee\u6539 SYSDBA.password, \u57fa\u672c\u4e0a\u53ea\u8981\u4fee\u6539\u7b2c\u4e8c\u884c\u5373\u53ef.<br \/>\n6. \u5927\u529f\u544a\u6210~<br \/>\nisql \u5247\u662f console \u6a21\u5f0f\u7684\u7ba1\u7406\u5de5\u5177,\u4f60\u53ef\u4ee5\u4f7f\u7528 select \/ insert \/ delete \/ create database &#8230;.\u7b49\u7b49\u7684SQL\u6558\u8ff0\u4f86\u4f5c\u7ba1\u7406.<br \/>\n\u4e5f\u53ef\u4ee5\u8f38\u5165 help \u4f86\u770b\u770b\u4f60\u53ef\u4ee5\u4f7f\u7528\u4ec0\u9ebc\u6307\u4ee4.<br \/>\n\u5b89\u5168\u6027\u8b70\u984c<br \/>\n==========<br \/>\n\u96d6\u7136\u662f\u4e00\u5957\u767c\u5c55\u4e86\u5f88\u4e45\u7684 Database,\u4f46\u662f\u5728\u6211\u770b\u4f86,\u4ed6\u7684\u5b89\u5168\u6027\u6709\u5f85\u52a0\u5f37~<br \/>\n\u9996\u5148\u662f \/etc\/init.d\/firebird \u8207 \/opt\/interbase\/SYSDBA.password, \u5bc6\u78bc\u4ee5\u660e\u78bc\u5f62\u5f0f\u5b58\u653e\u5728\u6a94\u6848\u4e2d, \u5982\u679c\u6b0a\u9650\u6c92\u8a2d\u70ba root only \u7684\u8a71,\u5bc6\u78bc\u5f88\u5bb9\u6613\u88ab\u7aca\u53d6,\u9577\u5ea6\u4e5f\u4e0d\u80fd\u8d85\u904e8\u78bc(\u771f\u61f7\u7591\u9810\u8a2d\u7684\u5bc6\u78bcmasterkey\u600e\u9ebc\u8a2d\u9032\u53bb\u7684).<br \/>\n\u518d\u4f86\u5c31\u662f\u8a2d\u5b9a\u4e2d,\u7f3a\u5c11\u7db2\u8def\u63a7\u5236\u7684\u8a2d\u5b9a,\u4e5f\u5c31\u662f\u7121\u6cd5\u6307\u5b9a\u6b64 server \u50c5\u9650\u54ea\u500b\u7db2\u6bb5\u7684\u4eba\u4f7f\u7528,\u4e5f\u4e0d\u652f\u63f4 SSL \u4e4b\u985e\u7684\u8a2d\u5b9a,\u5982\u6b64\u4e00\u4f86\u6211\u5c31\u4e0d\u592a\u6562\u7528 SS \u4f86\u5b89\u88dd\u4e86.<br \/>\n\u56e0\u70ba\u9019\u4e9b\u56e0\u7d20,\u6240\u4ee5\u6211\u5b89\u88dd CS.\u6211\u81ea\u5df1\u7684\u8a2d\u5b9a\u5927\u81f4\u5982\u4e0b:<br \/>\n1.\u589e\u52a0\u4e00\u500b\u540d\u70ba firebird \u7684 user (useradd firebird),\u6b64\u52d5\u4f5c\u540c\u6642\u6703\u589e\u52a0\u4e00\u500b firebird \u7684\u7fa4\u7d44.<br \/>\n2.\u5c07 \/opt\/interbase \u7684\u6240\u6709\u6a94\u6848\u7684 owner \u6539\u70ba firebird (chown -R firebird:firebird \/opt\/interbase)<br \/>\n3.\u4fee\u6539 \/etc\/xinetd.d\/firebird,\u5728\u5927\u62ec\u865f\u88e1\u9762\u52a0\u4e0a<br \/>\nuser=firebird<br \/>\nonly_from=192.168.0.0 127.0.0.1<br \/>\n\u4ee5\u907f\u514d\u4f7f\u7528 root \u6b0a\u9650,\u4e26\u5141\u8a31 192.168.0.0 \u9019\u500b\u7db2\u6bb5\u4ee5\u53ca\u672c\u6a5f\u53ef\u4ee5\u4f7f\u7528\u9019\u500b\u670d\u52d9.\u672c\u4f86\u6253\u7b97\u8981\u4f7f\u7528 tcpwrapper \u4f86\u4f5c\u63a7\u5236\u7684,\u5982\u6b64\u4e00\u4f86\u5c31\u53ef\u4ee5\u4f7f\u7528 \/etc\/hosts.allow \u548c \/etc\/hosts.deny \u4f86\u4f5c\u63a7\u5236.\u4f46\u662f\u6211\u52a0\u4e0a\u53bb\u4e4b\u5f8c\u537b\u6703\u7121\u6cd5\u9023\u7d50,\u53ea\u597d\u4f5c\u7f77.<br \/>\n\u627e\u5230 xinetd \u7684 pid,\u4e26\u5f37\u8feb xinetd \u91cd\u65b0\u8f09\u5165\u7d44\u614b\u5373\u53ef.<br \/>\n#ps -ef|grep xinetd<br \/>\n#kill -HUP xinetd_pid<br \/>\n4.\u5c07 \/etc\/xinetd.d\/firebird, \/opt\/interbase\/SYSDBA.password \u7684\u6b0a\u9650\u6539\u70ba 0400, owner read-only (chmod 0400 \/etc\/xinet.d\/firebird \/opt\/interbase\/SYSDBA.password)<br \/>\n5.\u8b8a\u66f4\u8cc7\u6599\u5eab\u5b58\u653e\u8def\u5f91\u7684 owner \u8207\u6b0a\u9650,\u5047\u8a2d\u8cc7\u6599\u5eab\u653e\u5728\/var\/database \u4e0b,\u90a3\u9ebc\u5c31<br \/>\n#chown -R firebird:firebird \/var\/database<br \/>\n#chmod -R 0770 \/var\/database<br \/>\n6.\u518d\u5c07\u5fc5\u8981\u7528\u5230 Firebird \u7684\u4f7f\u7528\u8005\u52a0\u5165 firebird \u7fa4\u7d44\u4e2d.<br \/>\n7.\u8b8a\u66f4\u7ba1\u7406\u8005\u5bc6\u78bc.<br \/>\n\u5176\u4ed6\u76f8\u95dc\u7684\u5b89\u5168\u6027\u8b70\u984c\u53ef\u4ee5\u53c3\u8003:<br \/>\nhttp:\/\/www.ibphoenix.com\/main.nfs?a=ibphoenix&#038;page=art_fb_security<br \/>\n\u6e2c\u8a66\u9023\u63a5<br \/>\n========<br \/>\n\u57f7\u884c \/opt\/interbase\/bin\/isql \u4ee5\u5f8c<br \/>\n\u5728 console \u8f38\u5165<br \/>\n&gt;connect &#8216;localhost:\/opt\/interbase\/examples\/employee.gdb&#8217;;<br \/>\n\u5982\u679c\u4e0d\u80fd\u9023\u63a5,\u6703\u51fa\u73fe\u932f\u8aa4\u8a0a\u606f.<br \/>\nFirebird 1.5 RC5<br \/>\n================<br \/>\n\u5728\u9019\u4e00\u500b\u7248\u672c\u88e1\u9762,\u5b89\u5168\u6027\u8b70\u984c\u6539\u9032\u4e86\u4e0d\u5c11,configuration file \u66f4\u540d\u70ba firebird.conf<br \/>\n\u88e1\u9762\u4e5f\u63d0\u4f9b\u4e86 RemoteBindAddress \u9019\u500b\u9078\u9805\u53ef\u4ee5\u6307\u5b9a.<br \/>\n\u9810\u8a2d\u5b89\u88dd\u8def\u5f91\u4e5f\u8b8a\u66f4\u70ba \/usr\/local\/firebird.<br \/>\n\u6240\u4ee5 1.5 \u7248\u61c9\u8a72\u662f\u4e00\u500b\u5b89\u5168\u6027\u8f03\u9ad8\u7684\u7248\u672c,\u8acb\u8010\u5fc3\u7b49\u5019\u6b63\u5f0f\u7248\u7684\u63a8\u51fa.<br \/>\n.Net Data Provider<br \/>\n==================<br \/>\n\u9664\u4e86 ODBC \u4e4b\u5916,\u5b98\u65b9\u7db2\u7ad9\u4e5f\u63d0\u4f9b\u4e86.Net Data Provider,\u9867\u540d\u601d\u7fa9\u5c31\u662f\u5c08\u9580\u7d66 ADO.Net \u7528\u7684.<br \/>\n\u82e5\u4f60\u662f\u4f7f\u7528 .Net framework 1.1 \u7684\u8a71,\u9700\u8981\u5148\u884c\u5b89\u88dd msvcr70.dll,\u8acb\u5148\u7528\u672c\u6a5f\u641c\u5c0b\u78ba\u5b9a\u4e00\u4e0b\u662f\u5426\u6709\u6b64\u6a94\u6848.<br \/>\n\u5982\u679c\u6c92\u6709,\u7528 google \u627e\u4e00\u4e0b,\u53ef\u4ee5\u627e\u5230\u4e0b\u8f09\u9ede (Microsoft \u672a\u63d0\u4f9b)<br \/>\n\u7136\u5f8c\u518d\u5b89\u88dd,\u4e00\u5207\u5c31\u6703\u5f88\u9806\u5229.<br \/>\n\u57fa\u672c\u4e0a,\u88e1\u9762\u7684\u985e\u5225\u90fd\u662f\u76f4\u63a5\u7531 ADO.Net \u7684 Connection, DataSet&#8230;\u7b49\u7b49\u985e\u5225\u7e7c\u627f\u51fa\u4f86,\u6240\u4ee5\u719f\u6089 ADO.Net \u7684\u8a71,\u5728\u4f7f\u7528\u4e0a\u4e26\u6c92\u6709\u4ec0\u9ebc\u56f0\u96e3.<br \/>\n\u53e6\u5916\u88e1\u9762\u4e5f\u63d0\u4f9b\u4e86 HtmlHelp \u7684\u8aaa\u660e\u6a94\u4ee5\u53ca\u7bc4\u4f8b\u7a0b\u5f0f,\u5404\u4f4d\u53ef\u4ee5\u81ea\u884c\u53c3\u8003\u4e4b.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u7248\u672c\u8207\u74b0\u5883 ========== Firebird: 1.0 OS: Red Hat Linux 9.0 \u5b89\u88dd ==== \u8acb\u5148\u9023\u7d50\u5230 http:\/\/sourceforge.net\/project\/showfiles.php?group_id=9028 \u9019\u500b\u7db2\u5740 \u6e96\u5099\u4e0b\u8f09 RPM(For Red Hat, SuSE, Mandrake) \u6216 tarball(For any distribuation) \u5305. \u9019\u88e1\u4f60\u6703\u770b\u5230\u6709\u5169\u500b\u6a94\u6848 \u4e00\u500b\u662f FirebirdCS-x.y.z.nnnn-xx.ixxx.rpm \u4e00\u500b\u5247\u662f FirebirdSS-x.y.z.nnnn-xx.ixxx.rpm \u9019\u5169\u500b\u6709\u4ec0\u9ebc\u5dee\u5225\u5462?? \u6240\u8b02\u7684 CS \u5c31\u662f Classic, \u8f03\u50b3\u7d71\u7684,\u4e4b\u524d,Firebird \u90fd\u662f\u639b\u5728 inetd, xinetd \u4e0b,\u505a\u70ba\u7db2\u8def\u670d\u52d9\u7684 \u4e5f\u5c31\u662f inetd \/ xinetd \u8ca0\u8cac\u50be\u807d\u7db2\u8def\u662f\u5426\u6709\u9700\u6c42,\u6709\u9700\u6c42,\u518d\u628a Firebird \u53eb\u8d77\u4f86,\u5c07\u9700\u6c42\u8f49\u4ea4\u7d66 Firebird. SS \u5247\u662f SuperServer, \u555f\u52d5\u6642\u5c31\u662f\u7368\u7acb\u8d77\u4f86\u50be\u807d\u7db2\u8def\u9700\u6c42,\u5982\u679c\u6709\u9700\u6c42,\u81ea\u5df1\u5c31\u51fa\u4f86\u670d\u52d9\u9019\u500b\u9700\u6c42. \u5728\u5b98\u65b9\u7db2\u7ad9\u88e1\u9762\u6709\u5c0d\u6b64\u4f5c\u8a73\u7d30\u7684\u6bd4\u8f03\u8207\u8aaa\u660e.http:\/\/www.ibphoenix.com\/main.nfs?a=ibphoenix&amp;page=ibp_ss_vs_classic \u4f9d\u64da\u6b64\u6587\u4ef6,\u5b83\u662f\u8aaa SuperServer &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/2003\/09\/firebird-on-linux\/\" class=\"more-link\">Continue reading<span class=\"screen-reader-text\"> &#8220;Firebird on Linux&#8221;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[8,4],"tags":[],"class_list":["post-165","post","type-post","status-publish","format-standard","hentry","category-linux-","category-4"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"jetpack_shortlink":"https:\/\/wp.me\/p2MOxp-2F","_links":{"self":[{"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/posts\/165","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/comments?post=165"}],"version-history":[{"count":0,"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/posts\/165\/revisions"}],"wp:attachment":[{"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/media?parent=165"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/categories?post=165"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ellery.no-ip.info\/wp\/thinkingmore\/wp-json\/wp\/v2\/tags?post=165"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}