Forums / General / "php beans"

"php beans"

Author Message

Tom C

Wednesday 12 January 2005 8:44:14 pm

This might better fit the suggestions topic, but...

I wonder if anyone thinks this is a radical new tool or if it has some application or usefulness for the eZ publish architecture.

http://www.phpbeans.com/index/news-app/story.4

http://www.phpbeans.com/index/news-app/story.3

The basic concept of phpBeans is a client/server model, where objects that live on the server are accessible to the client via a TCP/IP-based protocol.

phpBeans uses a single TCP/IP connection for an entire client/server session, whereas the others offer a stateless execution model, where each request to the server is an independent connection. This allows XML-RPC, SOAP, and REST to potentially change the underlying communication layer (ie. SOAP over HTTP over TCP/IP, or SOAP over SMTP over TCP/IP), whereas phpBeans is restricted to phpBeans over TCP/IP.

This means that XML-RPC, SOAP, and REST apply to a wider variety of situations than phpBeans. It also means that the phpBeans protocol is faster than any of them.

Calling objects via the phpBeans client API is almost completely transparent, the only difference being the way the objects are instantiated within the client (via the phpBeans API instead of with the usual $instance = new ObjectName () syntax).

Similarly on the server-side, creating objects (called 'beans' in phpBeans terminology) is simply a matter of writing an ordinary PHP class, with the only difference being that these classes extend a generic PHP_Bean class, and there are a few simply lines to be copied into the constructor method of each class.

With that small of a difference, your PHP applications have instantly gained a host of benefits, including:

* Increased scalability. A true separation of your application logic (beans) and your publishing code (the client, usually -- but not necessarily -- a web server serving a web-based application) enables you to better scale your applications by inserting redundancies, such as load-balancing, extra hardware, optimized operating systems, into each stage of the application execution. This is referred to as an n-tier application architecture.
* Increased security. By keeping your business logic a layer away from your public-facing servers, you gain more control over who can access your code and how.
* Increased flexibility. Having a solid, standards-based foundation to build on means more options as your application and company needs grow. And having a well architected application structure allows you to get more out of your code, without the worries of it growing into unmanageable spaghetti code that are often associated with Open Source technologies.

Some additional benefits offered specifically by the phpBeans specification include:

* Passworded access control based on a client's username and hostname/IP. You can also restrict any user to specific objects.
* Introspection and auto-discovery of object and method names and descriptions.
* Beans are simply ordinary PHP classes, nothing fancy or new to learn. The client API transparently mimicks the remote objects, so there really is nothing fancy or new to learn.
* Beans are documented using standard phpDoc documentation syntax. Methods are only published which have an @access public tag. And because phpDoc is used by the server itself, it encourages class writers to better document their code for use by others.
* Very simple object persistence layer, which enables storing and restoring of live objects in a single line of code.
* Built-in access log API for better visibility into your applications and their day-to-day real-world usage.
* The communication protocol is both very simple and very lightweight. Clients pass the server URI-formatted requests, and the server responds with serialized PHP data structures.
* While phpBeans is admittedly a PHP-centric specification, by no means does that exclude other languages and technologies, nor does it imply that either the client or the server must be written in PHP. In fact, projects are being planned that will expand the phpBeans compatibility to other languages as well.

Björn Dieding@xrow.de

Thursday 13 January 2005 12:36:01 am

I wasn't aware of this project. Thanks for the information.

In general I do think this this something some people should consider instead of using soap.

To me I can currently only see one down site. Those bean can be only read by a phpbeans client.

In gerneral we know that eZSOAP is not the best. I had done some modifications to enhance it and that it gets the features I needed for my projects.

Just some comments and those stuff i had in mind.

Looking for a new job? http://www.xrow.com/xrow-GmbH/Jobs
Looking for hosting? http://hostingezpublish.com
-----------------------------------------------------------------------------
GMT +01:00 Hannover, Germany
Web: http://www.xrow.com/

Thomas Nunninger

Thursday 13 January 2005 12:58:55 am

Hi Björn,

I didn't know the project, too. When I looked on the page, I didn't consider to use it instead of using Soap. I think, like Tom C wrote, it could be an additional layer in the eZ publish structure: you have your webserver (the client, probably in a DMZ) and in another - better secured - section of your network you place the bean server (written in C!).

I think this could

- increase security, because you do not have the database password saved on the public webserver; if someone logs in, you send a request to the bean server. So someone needs to crack the webserver and the bean server to reach the site data

- decrease response time, because (probably) the server caches the content and the bean client (eZ publish) is much simpler; eventually the hole persistence layer and more could be transfered to the bean server.

And in this point I see the problems: probably it is not so easy to migrate eZ publish to work with the bean server. There is so much program logic in the CMS that must be rewritten.

Perhaps it is easier with Derick's Scritp Running Machine, but I don't belive so. In my opinion, something like this would benefit the enterprise segment and would be a great plus to eZ publish. Perhaps this could be an option, when rewritting for eZ Publish version 4 with PHP 5 (and perhaps some PEAR-Packages?).

Another question/problem is the professional license...

Many greetings form Freiburg/Germany

Thomas

Björn Dieding@xrow.de

Friday 14 January 2005 9:59:24 am

Dear Thomas here are some additional comments on your post...

- increase security
This is a very interesting aspect.

- decrease response time, because (probably) the server caches the content and the bean client (eZ publish) is much simpler; eventually the hole persistence layer and more could be transfered to the bean server.

It is hard to imagine that this could improve the performance at all if such a layer is put infront of the persistence layer. That layer needs to reflect abilities of querying the data.

- not so easy to migrate eZ publish to work with the bean server.
totally, that why I think it should be used in with client/server interaction (reference to soap). Modules/Modules functions could maybe talk together over a network

Looking for a new job? http://www.xrow.com/xrow-GmbH/Jobs
Looking for hosting? http://hostingezpublish.com
-----------------------------------------------------------------------------
GMT +01:00 Hannover, Germany
Web: http://www.xrow.com/

Gabriel Ambuehl

Friday 14 January 2005 11:02:25 am

This sound a lot like a (simpler) port of Enterprise Java Beans to php. IMHO (and I'm far from there) EJB has never been a got idea. It's slow (distributed systems are always victim to that because of the serialization going on) and overly complex to program too. I wouldn't want to introduce that to PHP (many Java developers are avoiding EJB if at all possible).

Visit http://triligon.org

Tom C

Friday 14 January 2005 1:37:33 pm

Thanks to everyone for considering it.

To be more clear I should have set off all text in "quotes" after the two links in my original post, since that text was copied from the links--and wasn't mine. It betrays a knowledge I do not yet possess.

I have been surveying web programming languages and settled on php, so all I really know is there is something called "java beans" that works within Sun's java system. These phpbeans are actually the product of a company in Canada that also has a CMS on the market. Their concept looked interesting, to an untrained eye. I was not able to evaluate their usefulness, so I decided to ask.

Thanks for the feedback. Now, I'll get back to my study of the basics of linux, eZ publish, html, css, php...

orlando gall

Saturday 15 January 2005 3:06:05 am

Hello,
here are my thoughts if any is interesting

I think ezPublish should think about it a lot before considering using such concepts in the internal mechanisms of ezPublish. (I'm sure they will ;-) )

I'm sure phpbean is interesting as a project, and in some case can be use as an interoperability layer (with some very limitating prerequisites) but i don't think it's a good strategy for PHP and EzPublish to adopt those kind of design.

Even J2EE is now trying to evolve to concepts that are simpler. EJB, RMI and before , Corba, were far too complicated for building web application.

I'm sure both PHP and ezPublish have to go to Enterprise solutions.
But not copying J2EE, simply improving quality and still relying on the strength of PHP : simple to use, build for Web (and not for highly transactionnal back en d systems), simple to learn, simple to set up (no compilations, no Ant scripts for deployment ...)

They are to many projects trying to port J2EE to PHP. They are interesting as experiments, i don't think more.
I've look at this Phing project, it is porting well known Java tools "ANT" to PHP. For me, this is a "non sense" even if Phing is really a nice piece of code.

If ever anyone is interesting in looking at those kind of work, there is the Mojavi project, wich is an MVC implementation for PHP5, that could be really interesting, even when working on the port of ezPublish to PHP5.
http://www.mojavi.org/

eZ debug

Timing: Jan 18 2025 16:10:43
Script start
Timing: Jan 18 2025 16:10:43
Module start 'content'
Timing: Jan 18 2025 16:10:44
Module end 'content'
Timing: Jan 18 2025 16:10:44
Script end

Main resources:

Total runtime0.9838 sec
Peak memory usage4,096.0000 KB
Database Queries212

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0078 588.9531180.8594
Module start 'content' 0.00790.8655 769.8125728.3594
Module end 'content' 0.87340.1103 1,498.1719344.4688
Script end 0.9837  1,842.6406 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00410.4180210.0002
Check MTime0.00140.1435210.0001
Mysql Total
Database connection0.00080.077810.0008
Mysqli_queries0.911192.60732120.0043
Looping result0.00170.17602100.0000
Template Total0.954897.120.4774
Template load0.00180.185720.0009
Template processing0.953096.870820.4765
Template load and register function0.00020.017010.0002
states
state_id_array0.00070.066510.0007
state_identifier_array0.00100.102220.0005
Override
Cache load0.00160.1632730.0000
Sytem overhead
Fetch class attribute can translate value0.00110.112560.0002
Fetch class attribute name0.00120.117690.0001
XML
Image XML parsing0.00120.124760.0002
class_abstraction
Instantiating content class attribute0.00000.0014100.0000
General
dbfile0.00240.2404330.0001
String conversion0.00000.000730.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
7content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
15content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
9content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
3content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 36
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs